|
@ -3885,11 +3885,7 @@ void lcd_init() { |
|
|
int lcd_strlen(const char* s) { |
|
|
int lcd_strlen(const char* s) { |
|
|
int i = 0, j = 0; |
|
|
int i = 0, j = 0; |
|
|
while (s[i]) { |
|
|
while (s[i]) { |
|
|
#if ENABLED(MAPPER_NON) |
|
|
|
|
|
j++; |
|
|
|
|
|
#else |
|
|
|
|
|
if (PRINTABLE(s[i])) j++; |
|
|
if (PRINTABLE(s[i])) j++; |
|
|
#endif |
|
|
|
|
|
i++; |
|
|
i++; |
|
|
} |
|
|
} |
|
|
return j; |
|
|
return j; |
|
@ -3898,11 +3894,7 @@ int lcd_strlen(const char* s) { |
|
|
int lcd_strlen_P(const char* s) { |
|
|
int lcd_strlen_P(const char* s) { |
|
|
int j = 0; |
|
|
int j = 0; |
|
|
while (pgm_read_byte(s)) { |
|
|
while (pgm_read_byte(s)) { |
|
|
#if ENABLED(MAPPER_NON) |
|
|
|
|
|
j++; |
|
|
|
|
|
#else |
|
|
|
|
|
if (PRINTABLE(pgm_read_byte(s))) j++; |
|
|
if (PRINTABLE(pgm_read_byte(s))) j++; |
|
|
#endif |
|
|
|
|
|
s++; |
|
|
s++; |
|
|
} |
|
|
} |
|
|
return j; |
|
|
return j; |
|
@ -4162,28 +4154,28 @@ void lcd_update() { |
|
|
} // ELAPSED(ms, next_lcd_update_ms)
|
|
|
} // ELAPSED(ms, next_lcd_update_ms)
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#if DISABLED(STATUS_MESSAGE_SCROLLING) |
|
|
void pad_message_string() { |
|
|
|
|
|
|
|
|
void set_utf_strlen(char* s, uint8_t n) { |
|
|
|
|
|
uint8_t i = 0, j = 0; |
|
|
uint8_t i = 0, j = 0; |
|
|
while (s[i] && (j < n)) { |
|
|
char c; |
|
|
#if ENABLED(MAPPER_NON) |
|
|
while ((c = lcd_status_message[i]) && j < LCD_WIDTH) { |
|
|
j++; |
|
|
if (PRINTABLE(c)) j++; |
|
|
#else |
|
|
|
|
|
if (PRINTABLE(s[i])) j++; |
|
|
|
|
|
#endif |
|
|
|
|
|
i++; |
|
|
i++; |
|
|
} |
|
|
} |
|
|
while (j++ < n) s[i++] = ' '; |
|
|
if (true |
|
|
s[i] = '\0'; |
|
|
#if ENABLED(STATUS_MESSAGE_SCROLLING) |
|
|
|
|
|
&& j < LCD_WIDTH |
|
|
|
|
|
#endif |
|
|
|
|
|
) { |
|
|
|
|
|
// pad with spaces to fill up the line
|
|
|
|
|
|
while (j++ < LCD_WIDTH) lcd_status_message[i++] = ' '; |
|
|
|
|
|
// chop off at the edge
|
|
|
|
|
|
lcd_status_message[i] = '\0'; |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#endif // !STATUS_MESSAGE_SCROLLING
|
|
|
|
|
|
|
|
|
|
|
|
void lcd_finishstatus(bool persist=false) { |
|
|
void lcd_finishstatus(bool persist=false) { |
|
|
#if DISABLED(STATUS_MESSAGE_SCROLLING) |
|
|
|
|
|
set_utf_strlen(lcd_status_message, LCD_WIDTH); |
|
|
pad_message_string(); |
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#if !(ENABLED(LCD_PROGRESS_BAR) && (PROGRESS_MSG_EXPIRE > 0)) |
|
|
#if !(ENABLED(LCD_PROGRESS_BAR) && (PROGRESS_MSG_EXPIRE > 0)) |
|
|
UNUSED(persist); |
|
|
UNUSED(persist); |
|
|