mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
46345b9374
Move some code around so we can properly test whether the switch actually does anything. PR-URL: https://github.com/nodejs/node/pull/11255 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Sam Roberts <vieuxtech@gmail.com>
66 lines
2.2 KiB
C++
66 lines
2.2 KiB
C++
#include "node.h"
|
|
#include "node_i18n.h"
|
|
#include "env.h"
|
|
#include "env-inl.h"
|
|
#include "util.h"
|
|
#include "util-inl.h"
|
|
|
|
|
|
namespace node {
|
|
|
|
using v8::Context;
|
|
using v8::Local;
|
|
using v8::Object;
|
|
using v8::ReadOnly;
|
|
using v8::String;
|
|
using v8::Value;
|
|
|
|
// The config binding is used to provide an internal view of compile or runtime
|
|
// config options that are required internally by lib/*.js code. This is an
|
|
// alternative to dropping additional properties onto the process object as
|
|
// has been the practice previously in node.cc.
|
|
|
|
#define READONLY_BOOLEAN_PROPERTY(str) \
|
|
do { \
|
|
target->DefineOwnProperty(env->context(), \
|
|
OneByteString(env->isolate(), str), \
|
|
True(env->isolate()), ReadOnly).FromJust(); \
|
|
} while (0)
|
|
|
|
void InitConfig(Local<Object> target,
|
|
Local<Value> unused,
|
|
Local<Context> context) {
|
|
Environment* env = Environment::GetCurrent(context);
|
|
#ifdef NODE_HAVE_I18N_SUPPORT
|
|
|
|
READONLY_BOOLEAN_PROPERTY("hasIntl");
|
|
|
|
#ifdef NODE_HAVE_SMALL_ICU
|
|
READONLY_BOOLEAN_PROPERTY("hasSmallICU");
|
|
#endif // NODE_HAVE_SMALL_ICU
|
|
|
|
target->DefineOwnProperty(env->context(),
|
|
OneByteString(env->isolate(), "icuDataDir"),
|
|
OneByteString(env->isolate(), icu_data_dir.data()))
|
|
.FromJust();
|
|
|
|
#endif // NODE_HAVE_I18N_SUPPORT
|
|
|
|
if (config_preserve_symlinks)
|
|
READONLY_BOOLEAN_PROPERTY("preserveSymlinks");
|
|
|
|
if (!config_warning_file.empty()) {
|
|
Local<String> name = OneByteString(env->isolate(), "warningFile");
|
|
Local<String> value = String::NewFromUtf8(env->isolate(),
|
|
config_warning_file.data(),
|
|
v8::NewStringType::kNormal,
|
|
config_warning_file.size())
|
|
.ToLocalChecked();
|
|
target->DefineOwnProperty(env->context(), name, value).FromJust();
|
|
}
|
|
} // InitConfig
|
|
|
|
} // namespace node
|
|
|
|
NODE_MODULE_CONTEXT_AWARE_BUILTIN(config, node::InitConfig)
|