mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-25 05:35:25 +02:00 
			
		
		
		
	Fix newline not handled to to interpreting it as invisible char
This commit is contained in:
		| @@ -568,32 +568,32 @@ void CGUITTFont::draw(const core::stringw& text, const core::rect<s32>& position | ||||
| 		uchar32_t currentChar = *iter; | ||||
| 		n = getGlyphIndexByChar(currentChar); | ||||
| 		bool visible = (Invisible.findFirst(currentChar) == -1); | ||||
| 		bool lineBreak=false; | ||||
| 		if (currentChar == L'\r') // Mac or Windows breaks
 | ||||
| 		{ | ||||
| 			lineBreak = true; | ||||
| 			if (*(iter + 1) == (uchar32_t)'\n')	// Windows line breaks.
 | ||||
| 				currentChar = *(++iter); | ||||
| 		} | ||||
| 		else if (currentChar == (uchar32_t)'\n') // Unix breaks
 | ||||
| 		{ | ||||
| 			lineBreak = true; | ||||
| 		} | ||||
| 
 | ||||
| 		if (lineBreak) | ||||
| 		{ | ||||
| 			previousChar = 0; | ||||
| 			offset.Y += font_metrics.ascender / 64; | ||||
| 			offset.X = position.UpperLeftCorner.X; | ||||
| 
 | ||||
| 			if (hcenter) | ||||
| 				offset.X += (position.getWidth() - textDimension.Width) >> 1; | ||||
| 			++iter; | ||||
| 			continue; | ||||
| 		} | ||||
| 
 | ||||
| 		if (n > 0 && visible) | ||||
| 		{ | ||||
| 			bool lineBreak=false; | ||||
| 			if (currentChar == L'\r') // Mac or Windows breaks
 | ||||
| 			{ | ||||
| 				lineBreak = true; | ||||
| 				if (*(iter + 1) == (uchar32_t)'\n')	// Windows line breaks.
 | ||||
| 					currentChar = *(++iter); | ||||
| 			} | ||||
| 			else if (currentChar == (uchar32_t)'\n') // Unix breaks
 | ||||
| 			{ | ||||
| 				lineBreak = true; | ||||
| 			} | ||||
| 
 | ||||
| 			if (lineBreak) | ||||
| 			{ | ||||
| 				previousChar = 0; | ||||
| 				offset.Y += font_metrics.ascender / 64; | ||||
| 				offset.X = position.UpperLeftCorner.X; | ||||
| 
 | ||||
| 				if (hcenter) | ||||
| 					offset.X += (position.getWidth() - textDimension.Width) >> 1; | ||||
| 				++iter; | ||||
| 				continue; | ||||
| 			} | ||||
| 
 | ||||
| 			// Calculate the glyph offset.
 | ||||
| 			s32 offx = Glyphs[n-1].offset.X; | ||||
| 			s32 offy = (font_metrics.ascender / 64) - Glyphs[n-1].offset.Y; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user