[Fix] Patches after printf library update (#17584)
* Add missing '(' to print_bin_reverse32 declaration * Fix insufficient character buffers on satisfaction75 * Remove \0 character in format string and use corrected offset math instead on rocketboard 16 * Replace snprintf_ with snprintf for djinn * Explicitly ignore format checks for tracktyl manuform that uses %b specifier * Print properly escaped version string in command.c, as PRODUCT or other defines can contain constructs like 'Vendor keyboard 66%' which will be interpreted as a format specifier
This commit is contained in:
parent
8224f62806
commit
643f6367a1
@ -145,7 +145,7 @@ static char* get_time(void) {
|
|||||||
hour = 12;
|
hour = 12;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char time_str[8] = "";
|
static char time_str[11] = "";
|
||||||
sprintf(time_str, "%02d:%02d%s", hour, minute, is_pm ? "pm" : "am");
|
sprintf(time_str, "%02d:%02d%s", hour, minute, is_pm ? "pm" : "am");
|
||||||
|
|
||||||
return time_str;
|
return time_str;
|
||||||
@ -162,7 +162,7 @@ static char* get_date(void) {
|
|||||||
day = day_config;
|
day = day_config;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char date_str[11] = "";
|
static char date_str[15] = "";
|
||||||
sprintf(date_str, "%04d-%02d-%02d", year, month, day);
|
sprintf(date_str, "%04d-%02d-%02d", year, month, day);
|
||||||
|
|
||||||
return date_str;
|
return date_str;
|
||||||
|
@ -247,17 +247,17 @@ static bool has_shift_mod(void) {
|
|||||||
*/
|
*/
|
||||||
__attribute__((unused)) static void debug_charybdis_config_to_console(charybdis_config_t* config) {
|
__attribute__((unused)) static void debug_charybdis_config_to_console(charybdis_config_t* config) {
|
||||||
# ifdef CONSOLE_ENABLE
|
# ifdef CONSOLE_ENABLE
|
||||||
dprintf("(charybdis) process_record_kb: config = {\n"
|
IGNORE_FORMAT_WARNING(dprintf("(charybdis) process_record_kb: config = {\n"
|
||||||
"\traw = 0x%04X,\n"
|
"\traw = 0x%04X,\n"
|
||||||
"\t{\n"
|
"\t{\n"
|
||||||
"\t\tis_dragscroll_enabled=%b\n"
|
"\t\tis_dragscroll_enabled=%b\n"
|
||||||
"\t\tis_sniping_enabled=%b\n"
|
"\t\tis_sniping_enabled=%b\n"
|
||||||
"\t\tdefault_dpi=0x%02X (%ld)\n"
|
"\t\tdefault_dpi=0x%02X (%ld)\n"
|
||||||
"\t\tsniping_dpi=0x%01X (%ld)\n"
|
"\t\tsniping_dpi=0x%01X (%ld)\n"
|
||||||
"\t}\n"
|
"\t}\n"
|
||||||
"}\n",
|
"}\n",
|
||||||
config->raw, config->is_dragscroll_enabled, config->is_sniping_enabled, config->pointer_default_dpi, get_pointer_default_dpi(config), config->pointer_sniping_dpi, get_pointer_sniping_dpi(config));
|
config->raw, config->is_dragscroll_enabled, config->is_sniping_enabled, config->pointer_default_dpi, get_pointer_default_dpi(config), config->pointer_sniping_dpi, get_pointer_sniping_dpi(config)));
|
||||||
# endif // CONSOLE_ENABLE
|
# endif // CONSOLE_ENABLE
|
||||||
}
|
}
|
||||||
|
|
||||||
bool process_record_kb(uint16_t keycode, keyrecord_t* record) {
|
bool process_record_kb(uint16_t keycode, keyrecord_t* record) {
|
||||||
|
@ -107,10 +107,10 @@ static void oled_write_ln_centered(const char * data, bool inverted)
|
|||||||
char line_buf[21];
|
char line_buf[21];
|
||||||
|
|
||||||
// Amount to offset string from left side
|
// Amount to offset string from left side
|
||||||
uint8_t offset = (21 - strlen(data))/2;
|
uint8_t offset = (22 - strlen(data)) / 2;
|
||||||
|
|
||||||
// Formatted string centering... look, it works, don't ask how...
|
// Formatted string centering... look, it works, don't ask how...
|
||||||
snprintf(line_buf, 21, "%*s%s%*s\0", offset, "", data, offset, ""); // Centers data within 21 character buffer with null termination
|
snprintf(line_buf, 21, "%*s%s%*s", offset, "", data, offset, ""); // Centers data within 21 character buffer
|
||||||
|
|
||||||
oled_write_ln(line_buf, inverted);
|
oled_write_ln(line_buf, inverted);
|
||||||
}
|
}
|
||||||
|
@ -107,10 +107,10 @@ static void oled_write_ln_centered(const char * data, bool inverted)
|
|||||||
char line_buf[21];
|
char line_buf[21];
|
||||||
|
|
||||||
// Amount to offset string from left side
|
// Amount to offset string from left side
|
||||||
uint8_t offset = (21 - strlen(data))/2;
|
uint8_t offset = (22 - strlen(data))/2;
|
||||||
|
|
||||||
// Formatted string centering... look, it works, don't ask how...
|
// Formatted string centering... look, it works, don't ask how...
|
||||||
snprintf(line_buf, 21, "%*s%s%*s\0", offset, "", data, offset, ""); // Centers data within 21 character buffer with null termination
|
snprintf(line_buf, 21, "%*s%s%*s", offset, "", data, offset, ""); // Centers data within 21 character buffer
|
||||||
|
|
||||||
oled_write_ln(line_buf, inverted);
|
oled_write_ln(line_buf, inverted);
|
||||||
}
|
}
|
||||||
|
@ -158,7 +158,7 @@ void draw_ui_user(void) {
|
|||||||
if (hue_redraw || rgb_effect_redraw) {
|
if (hue_redraw || rgb_effect_redraw) {
|
||||||
static int max_rgb_xpos = 0;
|
static int max_rgb_xpos = 0;
|
||||||
xpos = 16;
|
xpos = 16;
|
||||||
snprintf_(buf, sizeof(buf), "rgb: %s", rgb_matrix_name(curr_effect));
|
snprintf(buf, sizeof(buf), "rgb: %s", rgb_matrix_name(curr_effect));
|
||||||
|
|
||||||
for (int i = 5; i < sizeof(buf); ++i) {
|
for (int i = 5; i < sizeof(buf); ++i) {
|
||||||
if (buf[i] == 0)
|
if (buf[i] == 0)
|
||||||
@ -187,7 +187,7 @@ void draw_ui_user(void) {
|
|||||||
|
|
||||||
static int max_layer_xpos = 0;
|
static int max_layer_xpos = 0;
|
||||||
xpos = 16;
|
xpos = 16;
|
||||||
snprintf_(buf, sizeof(buf), "layer: %s", layer_name);
|
snprintf(buf, sizeof(buf), "layer: %s", layer_name);
|
||||||
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
||||||
if (max_layer_xpos < xpos) {
|
if (max_layer_xpos < xpos) {
|
||||||
max_layer_xpos = xpos;
|
max_layer_xpos = xpos;
|
||||||
@ -200,7 +200,7 @@ void draw_ui_user(void) {
|
|||||||
if (hue_redraw || power_state_redraw) {
|
if (hue_redraw || power_state_redraw) {
|
||||||
static int max_power_xpos = 0;
|
static int max_power_xpos = 0;
|
||||||
xpos = 16;
|
xpos = 16;
|
||||||
snprintf_(buf, sizeof(buf), "power: %s", usbpd_str(kb_state.current_setting));
|
snprintf(buf, sizeof(buf), "power: %s", usbpd_str(kb_state.current_setting));
|
||||||
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
||||||
if (max_power_xpos < xpos) {
|
if (max_power_xpos < xpos) {
|
||||||
max_power_xpos = xpos;
|
max_power_xpos = xpos;
|
||||||
@ -213,7 +213,7 @@ void draw_ui_user(void) {
|
|||||||
if (hue_redraw || scan_redraw) {
|
if (hue_redraw || scan_redraw) {
|
||||||
static int max_scans_xpos = 0;
|
static int max_scans_xpos = 0;
|
||||||
xpos = 16;
|
xpos = 16;
|
||||||
snprintf_(buf, sizeof(buf), "scans: %d", (int)theme_state.scan_rate);
|
snprintf(buf, sizeof(buf), "scans: %d", (int)theme_state.scan_rate);
|
||||||
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
||||||
if (max_scans_xpos < xpos) {
|
if (max_scans_xpos < xpos) {
|
||||||
max_scans_xpos = xpos;
|
max_scans_xpos = xpos;
|
||||||
@ -226,7 +226,7 @@ void draw_ui_user(void) {
|
|||||||
if (hue_redraw || wpm_redraw) {
|
if (hue_redraw || wpm_redraw) {
|
||||||
static int max_wpm_xpos = 0;
|
static int max_wpm_xpos = 0;
|
||||||
xpos = 16;
|
xpos = 16;
|
||||||
snprintf_(buf, sizeof(buf), "wpm: %d", (int)get_current_wpm());
|
snprintf(buf, sizeof(buf), "wpm: %d", (int)get_current_wpm());
|
||||||
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
xpos += qp_drawtext_recolor(lcd, xpos, ypos, thintel, buf, curr_hue, 255, 255, curr_hue, 255, 0);
|
||||||
if (max_wpm_xpos < xpos) {
|
if (max_wpm_xpos < xpos) {
|
||||||
max_wpm_xpos = xpos;
|
max_wpm_xpos = xpos;
|
||||||
|
@ -161,7 +161,7 @@ static void command_common_help(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void print_version(void) {
|
static void print_version(void) {
|
||||||
print(/* clang-format off */
|
xprintf("%s", /* clang-format off */
|
||||||
"\n\t- Version -\n"
|
"\n\t- Version -\n"
|
||||||
"VID: " STR(VENDOR_ID) "(" STR(MANUFACTURER) ") "
|
"VID: " STR(VENDOR_ID) "(" STR(MANUFACTURER) ") "
|
||||||
"PID: " STR(PRODUCT_ID) "(" STR(PRODUCT) ") "
|
"PID: " STR(PRODUCT_ID) "(" STR(PRODUCT) ") "
|
||||||
|
@ -100,7 +100,7 @@ void print_set_sendchar(sendchar_func_t func);
|
|||||||
#define print_bin32(i) IGNORE_FORMAT_WARNING(xprintf("%032lb", i))
|
#define print_bin32(i) IGNORE_FORMAT_WARNING(xprintf("%032lb", i))
|
||||||
#define print_bin_reverse8(i) IGNORE_FORMAT_WARNING(xprintf("%08b", bitrev(i)))
|
#define print_bin_reverse8(i) IGNORE_FORMAT_WARNING(xprintf("%08b", bitrev(i)))
|
||||||
#define print_bin_reverse16(i) IGNORE_FORMAT_WARNING(xprintf("%016b", bitrev16(i)))
|
#define print_bin_reverse16(i) IGNORE_FORMAT_WARNING(xprintf("%016b", bitrev16(i)))
|
||||||
#define print_bin_reverse32(i) IGNORE_FORMAT_WARNINGxprintf("%032lb", bitrev32(i)))
|
#define print_bin_reverse32(i) IGNORE_FORMAT_WARNING(xprintf("%032lb", bitrev32(i)))
|
||||||
/* print value utility */
|
/* print value utility */
|
||||||
#define print_val_dec(v) xprintf(#v ": %u\n", v)
|
#define print_val_dec(v) xprintf(#v ": %u\n", v)
|
||||||
#define print_val_decs(v) xprintf(#v ": %d\n", v)
|
#define print_val_decs(v) xprintf(#v ": %d\n", v)
|
||||||
|
Loading…
Reference in New Issue
Block a user