forked from eden-emu/eden
		
	applet_swkbd: Include the null terminator in the buffer size calculation
Some games may interpret the read string as a null-terminated string instead of just reading the string up to buffer_size.
This commit is contained in:
		
							parent
							
								
									e13e98d99d
								
							
						
					
					
						commit
						0971b90782
					
				
					 1 changed files with 4 additions and 2 deletions
				
			
		|  | @ -377,7 +377,8 @@ void SoftwareKeyboard::SubmitForTextCheck(std::u16string submitted_text) { | |||
| 
 | ||||
|     if (swkbd_config_common.use_utf8) { | ||||
|         std::string utf8_submitted_text = Common::UTF16ToUTF8(current_text); | ||||
|         const u64 buffer_size = utf8_submitted_text.size(); | ||||
|         // Include the null terminator in the buffer size.
 | ||||
|         const u64 buffer_size = utf8_submitted_text.size() + 1; | ||||
| 
 | ||||
|         LOG_DEBUG(Service_AM, "\nBuffer Size: {}\nUTF-8 Submitted Text: {}", buffer_size, | ||||
|                   utf8_submitted_text); | ||||
|  | @ -386,7 +387,8 @@ void SoftwareKeyboard::SubmitForTextCheck(std::u16string submitted_text) { | |||
|         std::memcpy(out_data.data() + sizeof(u64), utf8_submitted_text.data(), | ||||
|                     utf8_submitted_text.size()); | ||||
|     } else { | ||||
|         const u64 buffer_size = current_text.size() * sizeof(char16_t); | ||||
|         // Include the null terminator in the buffer size.
 | ||||
|         const u64 buffer_size = (current_text.size() + 1) * sizeof(char16_t); | ||||
| 
 | ||||
|         LOG_DEBUG(Service_AM, "\nBuffer Size: {}\nUTF-16 Submitted Text: {}", buffer_size, | ||||
|                   Common::UTF16ToUTF8(current_text)); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Morph
						Morph