|
|
@ -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);
|
|
|
|