1
0
mirror of https://github.com/systemd/systemd.git synced 2025-03-19 22:50:17 +03:00

qrcode-util: add debug message to show why a qrcode wasn't printed

(cherry picked from commit f0764b98e5c136cb948a8034949064f610acca24)
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2024-10-28 13:15:32 +01:00 committed by Luca Boccassi
parent 6a4ff7a5c1
commit b3fd2104bc

View File

@ -178,8 +178,10 @@ int print_qrcode_full(FILE *out, const char *header, const char *string, unsigne
/* If this is not a UTF-8 system or ANSI colors aren't supported/disabled don't print any QR
* codes */
if (!is_locale_utf8() || !colors_enabled())
return -EOPNOTSUPP;
if (!is_locale_utf8())
return log_debug_errno(SYNTHETIC_ERRNO(EOPNOTSUPP), "Not an UTF-8 system, cannot print qrcode");
if (!colors_enabled())
return log_debug_errno(SYNTHETIC_ERRNO(EOPNOTSUPP), "Colors are disabled, cannot print qrcode");
r = dlopen_qrencode();
if (r < 0)
@ -187,21 +189,21 @@ int print_qrcode_full(FILE *out, const char *header, const char *string, unsigne
qr = sym_QRcode_encodeString(string, 0, QR_ECLEVEL_L, QR_MODE_8, 1);
if (!qr)
return -ENOMEM;
return log_oom_debug();
if (row != UINT_MAX && column != UINT_MAX) {
int fd;
unsigned qr_code_width, qr_code_height;
fd = fileno(out);
int fd = fileno(out);
if (fd < 0)
return log_debug_errno(errno, "Failed to get file descriptor from the file stream: %m");
qr_code_width = qr_code_height = qr->width + 8;
qr_code_width = qr_code_height = qr->width + 8;
if (column + qr_code_width > tty_width)
column = tty_width - qr_code_width;
/* Terminal characters are twice as high as they are wide so it's qr_code_height / 2,
* our QR code prints an extra new line, so we have -1 as well */
* our QR code prints an extra new line, so we have -1 as well */
if (row + qr_code_height > tty_height)
row = tty_height - (qr_code_height / 2 ) - 1;
@ -217,7 +219,6 @@ int print_qrcode_full(FILE *out, const char *header, const char *string, unsigne
fprintf(out, "\n%s:\n\n", header);
write_qrcode(out, qr, row, column);
fputc('\n', out);
sym_QRcode_free(qr);