Skip to content

Commit 2ea515e

Browse files
committed
src: use enum class instead of enum in node_i18n
"enum class" has more advantages than "enum" because it's strongly typed and scoped. Refs: https://isocpp.org/wiki/faq/cpp11-language-types#enum-class
1 parent fac00cd commit 2ea515e

File tree

2 files changed

+8
-7
lines changed

2 files changed

+8
-7
lines changed

src/node_i18n.cc

+6-5
Original file line numberDiff line numberDiff line change
@@ -642,13 +642,13 @@ int32_t ToUnicode(MaybeStackBuffer<char>* buf,
642642
int32_t ToASCII(MaybeStackBuffer<char>* buf,
643643
const char* input,
644644
size_t length,
645-
enum idna_mode mode) {
645+
idna_mode mode) {
646646
UErrorCode status = U_ZERO_ERROR;
647647
uint32_t options = // CheckHyphens = false; handled later
648648
UIDNA_CHECK_BIDI | // CheckBidi = true
649649
UIDNA_CHECK_CONTEXTJ | // CheckJoiners = true
650650
UIDNA_NONTRANSITIONAL_TO_ASCII; // Nontransitional_Processing
651-
if (mode == IDNA_STRICT) {
651+
if (mode == idna_mode::IDNA_STRICT) {
652652
options |= UIDNA_USE_STD3_RULES; // UseSTD3ASCIIRules = beStrict
653653
// VerifyDnsLength = beStrict;
654654
// handled later
@@ -696,14 +696,15 @@ int32_t ToASCII(MaybeStackBuffer<char>* buf,
696696
info.errors &= ~UIDNA_ERROR_LEADING_HYPHEN;
697697
info.errors &= ~UIDNA_ERROR_TRAILING_HYPHEN;
698698

699-
if (mode != IDNA_STRICT) {
699+
if (mode != idna_mode::IDNA_STRICT) {
700700
// VerifyDnsLength = beStrict
701701
info.errors &= ~UIDNA_ERROR_EMPTY_LABEL;
702702
info.errors &= ~UIDNA_ERROR_LABEL_TOO_LONG;
703703
info.errors &= ~UIDNA_ERROR_DOMAIN_NAME_TOO_LONG;
704704
}
705705

706-
if (U_FAILURE(status) || (mode != IDNA_LENIENT && info.errors != 0)) {
706+
if (U_FAILURE(status) ||
707+
(mode != idna_mode::IDNA_LENIENT && info.errors != 0)) {
707708
len = -1;
708709
buf->SetLength(0);
709710
} else {
@@ -741,7 +742,7 @@ static void ToASCII(const FunctionCallbackInfo<Value>& args) {
741742
Utf8Value val(env->isolate(), args[0]);
742743
// optional arg
743744
bool lenient = args[1]->BooleanValue(env->isolate());
744-
enum idna_mode mode = lenient ? IDNA_LENIENT : IDNA_DEFAULT;
745+
idna_mode mode = lenient ? idna_mode::IDNA_LENIENT : idna_mode::IDNA_DEFAULT;
745746

746747
MaybeStackBuffer<char> buf;
747748
int32_t len = ToASCII(&buf, *val, val.length(), mode);

src/node_i18n.h

+2-2
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@ bool InitializeICUDirectory(const std::string& path);
4242

4343
void SetDefaultTimeZone(const char* tzid);
4444

45-
enum idna_mode {
45+
enum class idna_mode {
4646
// Default mode for maximum compatibility.
4747
IDNA_DEFAULT,
4848
// Ignore all errors in IDNA conversion, if possible.
@@ -58,7 +58,7 @@ enum idna_mode {
5858
int32_t ToASCII(MaybeStackBuffer<char>* buf,
5959
const char* input,
6060
size_t length,
61-
enum idna_mode mode = IDNA_DEFAULT);
61+
idna_mode mode = idna_mode::IDNA_DEFAULT);
6262

6363
// Implements the WHATWG URL Standard "domain to Unicode" algorithm.
6464
// https://url.spec.whatwg.org/#concept-domain-to-unicode

0 commit comments

Comments
 (0)