|  |  |  | @ -3252,23 +3252,6 @@ bool ImGui::InputTextEx(const char* label, char* buf, int buf_size, const ImVec2 | 
			
		
	
		
			
				
					|  |  |  |  |     if (hovered) | 
			
		
	
		
			
				
					|  |  |  |  |         g.MouseCursor = ImGuiMouseCursor_TextInput; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Password pushes a temporary font with only a fallback glyph
 | 
			
		
	
		
			
				
					|  |  |  |  |     if (is_password) | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         const ImFontGlyph* glyph = g.Font->FindGlyph('*'); | 
			
		
	
		
			
				
					|  |  |  |  |         ImFont* password_font = &g.InputTextPasswordFont; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FontSize = g.Font->FontSize; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Scale = g.Font->Scale; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->DisplayOffset = g.Font->DisplayOffset; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Ascent = g.Font->Ascent; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Descent = g.Font->Descent; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->ContainerAtlas = g.Font->ContainerAtlas; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FallbackGlyph = glyph; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FallbackAdvanceX = glyph->AdvanceX; | 
			
		
	
		
			
				
					|  |  |  |  |         IM_ASSERT(password_font->Glyphs.empty() && password_font->IndexAdvanceX.empty() && password_font->IndexLookup.empty()); | 
			
		
	
		
			
				
					|  |  |  |  |         PushFont(password_font); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // NB: we are only allowed to access 'edit_state' if we are the active widget.
 | 
			
		
	
		
			
				
					|  |  |  |  |     ImGuiInputTextState* state = NULL; | 
			
		
	
		
			
				
					|  |  |  |  |     if (g.InputTextState.ID == id) | 
			
		
	
	
		
			
				
					|  |  |  | @ -3353,10 +3336,6 @@ bool ImGui::InputTextEx(const char* label, char* buf, int buf_size, const ImVec2 | 
			
		
	
		
			
				
					|  |  |  |  |     if (g.ActiveId == id && io.MouseClicked[0] && !init_state && !init_make_active) //-V560
 | 
			
		
	
		
			
				
					|  |  |  |  |         clear_active_id = true; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     bool value_changed = false; | 
			
		
	
		
			
				
					|  |  |  |  |     bool enter_pressed = false; | 
			
		
	
		
			
				
					|  |  |  |  |     int backup_current_text_length = 0; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // When read-only we always use the live data passed to the function
 | 
			
		
	
		
			
				
					|  |  |  |  |     // FIXME-OPT: Because our selection/cursor code currently needs the wide text we need to convert it when active, which is not ideal :(
 | 
			
		
	
		
			
				
					|  |  |  |  |     if (is_readonly && state != NULL) | 
			
		
	
	
		
			
				
					|  |  |  | @ -3373,7 +3352,31 @@ bool ImGui::InputTextEx(const char* label, char* buf, int buf_size, const ImVec2 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Lock the decision of whether we are going to take the path displaying the cursor or selection
 | 
			
		
	
		
			
				
					|  |  |  |  |     const bool render_cursor = (g.ActiveId == id) || (state && user_scroll_active); | 
			
		
	
		
			
				
					|  |  |  |  |     const bool render_selection = state && state->HasSelection() && (RENDER_SELECTION_WHEN_INACTIVE || render_cursor); | 
			
		
	
		
			
				
					|  |  |  |  |     bool value_changed = false; | 
			
		
	
		
			
				
					|  |  |  |  |     bool enter_pressed = false; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Password pushes a temporary font with only a fallback glyph
 | 
			
		
	
		
			
				
					|  |  |  |  |     if (is_password) | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         const ImFontGlyph* glyph = g.Font->FindGlyph('*'); | 
			
		
	
		
			
				
					|  |  |  |  |         ImFont* password_font = &g.InputTextPasswordFont; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FontSize = g.Font->FontSize; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Scale = g.Font->Scale; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->DisplayOffset = g.Font->DisplayOffset; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Ascent = g.Font->Ascent; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->Descent = g.Font->Descent; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->ContainerAtlas = g.Font->ContainerAtlas; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FallbackGlyph = glyph; | 
			
		
	
		
			
				
					|  |  |  |  |         password_font->FallbackAdvanceX = glyph->AdvanceX; | 
			
		
	
		
			
				
					|  |  |  |  |         IM_ASSERT(password_font->Glyphs.empty() && password_font->IndexAdvanceX.empty() && password_font->IndexLookup.empty()); | 
			
		
	
		
			
				
					|  |  |  |  |         PushFont(password_font); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Process mouse inputs and character inputs
 | 
			
		
	
		
			
				
					|  |  |  |  |     int backup_current_text_length = 0; | 
			
		
	
		
			
				
					|  |  |  |  |     if (g.ActiveId == id) | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         IM_ASSERT(state != NULL); | 
			
		
	
	
		
			
				
					|  |  |  | @ -3725,8 +3728,6 @@ bool ImGui::InputTextEx(const char* label, char* buf, int buf_size, const ImVec2 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // Render text. We currently only render selection when the widget is active or while scrolling.
 | 
			
		
	
		
			
				
					|  |  |  |  |     // FIXME: We could remove the '&& render_cursor' to keep rendering selection when inactive.
 | 
			
		
	
		
			
				
					|  |  |  |  |     const bool render_cursor = (g.ActiveId == id) || (state && user_scroll_active); | 
			
		
	
		
			
				
					|  |  |  |  |     const bool render_selection = state && state->HasSelection() && (RENDER_SELECTION_WHEN_INACTIVE || render_cursor); | 
			
		
	
		
			
				
					|  |  |  |  |     if (render_cursor || render_selection) | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         // Render text (with cursor and selection)
 | 
			
		
	
	
		
			
				
					|  |  |  | 
 |