Skip to content

src: move more process methods initialization in bootstrap/node.js

Instead of:

  • Writing methods onto the process directly in C++ during SetupProcessObject() and overwrite with argument checks later
  • Or, wrapping and writing them in internal/process/*.js

Do:

  • Move the C++ implementations in node_process.cc and mark them static wherever possible
  • Expose the C++ methods through a new internalBinding('process_methods')
  • Wrap the methods in internal/process/*.js in a side-effect-free manner and return them back to internal/bootstrap/node.js
  • Centralize the write to the process object based on conditions in bootstrap/node.js

So it's easier to see what methods are attached to the process object during bootstrap under what condition and in what order.

The eventual goal is to figure out the dependency of process methods and the write/read access to the process object during bootstrap, group these access properly and remove the process properties that should not be exposed to users this way.

Also correct the NODE_PERFORMANCE_MILESTONE_BOOTSTRAP_COMPLETE milestone which should be marked before code execution.

Refs: https://github.com/nodejs/node/issues/24961

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • commit message follows commit guidelines

Merge request reports

Loading