mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-19 08:24:00 +00:00
printf: Remove duplicated conversion functions
This commit is contained in:
parent
89996c0c8a
commit
90e763b279
1 changed files with 3 additions and 97 deletions
|
@ -108,100 +108,6 @@ struct builtin_printf_state_t {
|
||||||
|
|
||||||
static bool is_octal_digit(wchar_t c) { return iswdigit(c) && c < L'8'; }
|
static bool is_octal_digit(wchar_t c) { return iswdigit(c) && c < L'8'; }
|
||||||
|
|
||||||
static int hex_to_bin(const wchar_t &c) {
|
|
||||||
switch (c) {
|
|
||||||
case L'0': {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
case L'1': {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
case L'2': {
|
|
||||||
return 2;
|
|
||||||
}
|
|
||||||
case L'3': {
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
case L'4': {
|
|
||||||
return 4;
|
|
||||||
}
|
|
||||||
case L'5': {
|
|
||||||
return 5;
|
|
||||||
}
|
|
||||||
case L'6': {
|
|
||||||
return 6;
|
|
||||||
}
|
|
||||||
case L'7': {
|
|
||||||
return 7;
|
|
||||||
}
|
|
||||||
case L'8': {
|
|
||||||
return 8;
|
|
||||||
}
|
|
||||||
case L'9': {
|
|
||||||
return 9;
|
|
||||||
}
|
|
||||||
case L'a':
|
|
||||||
case L'A': {
|
|
||||||
return 10;
|
|
||||||
}
|
|
||||||
case L'b':
|
|
||||||
case L'B': {
|
|
||||||
return 11;
|
|
||||||
}
|
|
||||||
case L'c':
|
|
||||||
case L'C': {
|
|
||||||
return 12;
|
|
||||||
}
|
|
||||||
case L'd':
|
|
||||||
case L'D': {
|
|
||||||
return 13;
|
|
||||||
}
|
|
||||||
case L'e':
|
|
||||||
case L'E': {
|
|
||||||
return 14;
|
|
||||||
}
|
|
||||||
case L'f':
|
|
||||||
case L'F': {
|
|
||||||
return 15;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int octal_to_bin(wchar_t c) {
|
|
||||||
switch (c) {
|
|
||||||
case L'0': {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
case L'1': {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
case L'2': {
|
|
||||||
return 2;
|
|
||||||
}
|
|
||||||
case L'3': {
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
case L'4': {
|
|
||||||
return 4;
|
|
||||||
}
|
|
||||||
case L'5': {
|
|
||||||
return 5;
|
|
||||||
}
|
|
||||||
case L'6': {
|
|
||||||
return 6;
|
|
||||||
}
|
|
||||||
case L'7': {
|
|
||||||
return 7;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void builtin_printf_state_t::nonfatal_error(const wchar_t *fmt, ...) {
|
void builtin_printf_state_t::nonfatal_error(const wchar_t *fmt, ...) {
|
||||||
// Don't error twice.
|
// Don't error twice.
|
||||||
if (early_exit) return;
|
if (early_exit) return;
|
||||||
|
@ -366,7 +272,7 @@ long builtin_printf_state_t::print_esc(const wchar_t *escstart, bool octal_0) {
|
||||||
if (*p == L'x') {
|
if (*p == L'x') {
|
||||||
// A hexadecimal \xhh escape sequence must have 1 or 2 hex. digits.
|
// A hexadecimal \xhh escape sequence must have 1 or 2 hex. digits.
|
||||||
for (esc_length = 0, ++p; esc_length < 2 && iswxdigit(*p); ++esc_length, ++p)
|
for (esc_length = 0, ++p; esc_length < 2 && iswxdigit(*p); ++esc_length, ++p)
|
||||||
esc_value = esc_value * 16 + hex_to_bin(*p);
|
esc_value = esc_value * 16 + convert_digit(*p, 16);
|
||||||
if (esc_length == 0) this->fatal_error(_(L"missing hexadecimal number in escape"));
|
if (esc_length == 0) this->fatal_error(_(L"missing hexadecimal number in escape"));
|
||||||
this->append_output(ENCODE_DIRECT_BASE + esc_value % 256);
|
this->append_output(ENCODE_DIRECT_BASE + esc_value % 256);
|
||||||
} else if (is_octal_digit(*p)) {
|
} else if (is_octal_digit(*p)) {
|
||||||
|
@ -375,7 +281,7 @@ long builtin_printf_state_t::print_esc(const wchar_t *escstart, bool octal_0) {
|
||||||
// Wrap mod 256, which matches historic behavior.
|
// Wrap mod 256, which matches historic behavior.
|
||||||
for (esc_length = 0, p += octal_0 && *p == L'0'; esc_length < 3 && is_octal_digit(*p);
|
for (esc_length = 0, p += octal_0 && *p == L'0'; esc_length < 3 && is_octal_digit(*p);
|
||||||
++esc_length, ++p)
|
++esc_length, ++p)
|
||||||
esc_value = esc_value * 8 + octal_to_bin(*p);
|
esc_value = esc_value * 8 + convert_digit(*p, 8);
|
||||||
this->append_output(ENCODE_DIRECT_BASE + esc_value % 256);
|
this->append_output(ENCODE_DIRECT_BASE + esc_value % 256);
|
||||||
} else if (*p && std::wcschr(L"\"\\abcefnrtv", *p)) {
|
} else if (*p && std::wcschr(L"\"\\abcefnrtv", *p)) {
|
||||||
print_esc_char(*p++);
|
print_esc_char(*p++);
|
||||||
|
@ -391,7 +297,7 @@ long builtin_printf_state_t::print_esc(const wchar_t *escstart, bool octal_0) {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
uni_value = uni_value * 16 + hex_to_bin(*p);
|
uni_value = uni_value * 16 + convert_digit(*p, 16);
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue