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