@ -4273,10 +4273,11 @@ bool ImGui::InputTextEx(const char* label, const char* hint, char* buf, int buf_ 
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    IM_ASSERT ( callback_data . Buf  = =  state - > TextA . Data ) ;   // Invalid to modify those fields
   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    IM_ASSERT ( callback_data . BufSize  = =  state - > BufCapacityA ) ;   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    IM_ASSERT ( callback_data . Flags  = =  flags ) ;   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . CursorPos  ! =  utf8_cursor_pos )             {  state - > Stb . cursor  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . CursorPos ) ;  state - > CursorFollow  =  true ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . SelectionStart  ! =  utf8_selection_start )   {  state - > Stb . select_start  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . SelectionStart ) ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . SelectionEnd  ! =  utf8_selection_end )       {  state - > Stb . select_end  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . SelectionEnd ) ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . BufDirty )   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    const  bool  buf_dirty  =  callback_data . BufDirty ;   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . CursorPos  ! =  utf8_cursor_pos  | |  buf_dirty )             {  state - > Stb . cursor  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . CursorPos ) ;  state - > CursorFollow  =  true ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . SelectionStart  ! =  utf8_selection_start  | |  buf_dirty )   {  state - > Stb . select_start  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . SelectionStart ) ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( callback_data . SelectionEnd  ! =  utf8_selection_end  | |  buf_dirty )       {  state - > Stb . select_end  =  ImTextCountCharsFromUtf8 ( callback_data . Buf ,  callback_data . Buf  +  callback_data . SelectionEnd ) ;  }   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    if  ( buf_dirty )   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                    {   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                        IM_ASSERT ( callback_data . BufTextLen  = =  ( int ) strlen ( callback_data . Buf ) ) ;  // You need to maintain BufTextLen if you change the text!
   
				
			 
			
		
	
		
			
				
					 
					 
				
				 
				 
				
					                        if  ( callback_data . BufTextLen  >  backup_current_text_length  & &  is_resizable )