|  | @@ -36,7 +36,7 @@ Index of this file:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #include <stdio.h>      // vsnprintf, sscanf, printf
 | 
	
		
			
				|  |  |  #if !defined(alloca)
 | 
	
		
			
				|  |  | -#if defined(__GLIBC__) || defined(__sun) || defined(__CYGWIN__) || defined(__APPLE__) || defined(__SWITCH__)
 | 
	
		
			
				|  |  | +#if defined(__GLIBC__) || defined(__sun) || defined(__APPLE__) || defined(__NEWLIB__)
 | 
	
		
			
				|  |  |  #include <alloca.h>     // alloca (glibc uses <alloca.h>. Note that Cygwin may have _WIN32 defined, so the order matters here)
 | 
	
		
			
				|  |  |  #elif defined(_WIN32)
 | 
	
		
			
				|  |  |  #include <malloc.h>     // alloca
 | 
	
	
		
			
				|  | @@ -621,7 +621,7 @@ void ImDrawList::PrimQuadUV(const ImVec2& a, const ImVec2& b, const ImVec2& c, c
 | 
	
		
			
				|  |  |      _IdxWritePtr += 6;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -// On AddPolyline() and AddConvexPolyFilled() we intentionally avoid using ImVec2 and superflous function calls to optimize debug/non-inlined builds.
 | 
	
		
			
				|  |  | +// On AddPolyline() and AddConvexPolyFilled() we intentionally avoid using ImVec2 and superfluous function calls to optimize debug/non-inlined builds.
 | 
	
		
			
				|  |  |  // Those macros expects l-values.
 | 
	
		
			
				|  |  |  #define IM_NORMALIZE2F_OVER_ZERO(VX,VY)     do { float d2 = VX*VX + VY*VY; if (d2 > 0.0f) { float inv_len = 1.0f / ImSqrt(d2); VX *= inv_len; VY *= inv_len; } } while (0)
 | 
	
		
			
				|  |  |  #define IM_FIXNORMAL2F(VX,VY)               do { float d2 = VX*VX + VY*VY; if (d2 < 0.5f) d2 = 0.5f; float inv_lensq = 1.0f / d2; VX *= inv_lensq; VY *= inv_lensq; } while (0)
 | 
	
	
		
			
				|  | @@ -690,7 +690,7 @@ void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32
 | 
	
		
			
				|  |  |                  dm_x *= AA_SIZE;
 | 
	
		
			
				|  |  |                  dm_y *= AA_SIZE;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -                // Add temporary vertexes
 | 
	
		
			
				|  |  | +                // Add temporary vertices
 | 
	
		
			
				|  |  |                  ImVec2* out_vtx = &temp_points[i2*2];
 | 
	
		
			
				|  |  |                  out_vtx[0].x = points[i2].x + dm_x;
 | 
	
		
			
				|  |  |                  out_vtx[0].y = points[i2].y + dm_y;
 | 
	
	
		
			
				|  | @@ -707,7 +707,7 @@ void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32
 | 
	
		
			
				|  |  |                  idx1 = idx2;
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -            // Add vertexes
 | 
	
		
			
				|  |  | +            // Add vertices
 | 
	
		
			
				|  |  |              for (int i = 0; i < points_count; i++)
 | 
	
		
			
				|  |  |              {
 | 
	
		
			
				|  |  |                  _VtxWritePtr[0].pos = points[i];          _VtxWritePtr[0].uv = uv; _VtxWritePtr[0].col = col;
 | 
	
	
		
			
				|  | @@ -747,7 +747,7 @@ void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32
 | 
	
		
			
				|  |  |                  float dm_in_x = dm_x * half_inner_thickness;
 | 
	
		
			
				|  |  |                  float dm_in_y = dm_y * half_inner_thickness;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -                // Add temporary vertexes
 | 
	
		
			
				|  |  | +                // Add temporary vertices
 | 
	
		
			
				|  |  |                  ImVec2* out_vtx = &temp_points[i2*4];
 | 
	
		
			
				|  |  |                  out_vtx[0].x = points[i2].x + dm_out_x;
 | 
	
		
			
				|  |  |                  out_vtx[0].y = points[i2].y + dm_out_y;
 | 
	
	
		
			
				|  | @@ -770,7 +770,7 @@ void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32
 | 
	
		
			
				|  |  |                  idx1 = idx2;
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -            // Add vertexes
 | 
	
		
			
				|  |  | +            // Add vertices
 | 
	
		
			
				|  |  |              for (int i = 0; i < points_count; i++)
 | 
	
		
			
				|  |  |              {
 | 
	
		
			
				|  |  |                  _VtxWritePtr[0].pos = temp_points[i*4+0]; _VtxWritePtr[0].uv = uv; _VtxWritePtr[0].col = col_trans;
 | 
	
	
		
			
				|  | @@ -1549,7 +1549,6 @@ ImFontConfig::ImFontConfig()
 | 
	
		
			
				|  |  |  // The white texels on the top left are the ones we'll use everywhere in Dear ImGui to render filled shapes.
 | 
	
		
			
				|  |  |  const int FONT_ATLAS_DEFAULT_TEX_DATA_W_HALF = 108;
 | 
	
		
			
				|  |  |  const int FONT_ATLAS_DEFAULT_TEX_DATA_H      = 27;
 | 
	
		
			
				|  |  | -const unsigned int FONT_ATLAS_DEFAULT_TEX_DATA_ID = 0x80000000;
 | 
	
		
			
				|  |  |  static const char FONT_ATLAS_DEFAULT_TEX_DATA_PIXELS[FONT_ATLAS_DEFAULT_TEX_DATA_W_HALF * FONT_ATLAS_DEFAULT_TEX_DATA_H + 1] =
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |      "..-         -XXXXXXX-    X    -           X           -XXXXXXX          -          XXXXXXX-     XX          "
 | 
	
	
		
			
				|  | @@ -1832,14 +1831,11 @@ ImFont* ImFontAtlas::AddFontFromMemoryCompressedBase85TTF(const char* compressed
 | 
	
		
			
				|  |  |      return font;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -int ImFontAtlas::AddCustomRectRegular(unsigned int id, int width, int height)
 | 
	
		
			
				|  |  | +int ImFontAtlas::AddCustomRectRegular(int width, int height)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | -    // Breaking change on 2019/11/21 (1.74): ImFontAtlas::AddCustomRectRegular() now requires an ID >= 0x110000 (instead of >= 0x10000)
 | 
	
		
			
				|  |  | -    IM_ASSERT(id >= 0x110000);
 | 
	
		
			
				|  |  |      IM_ASSERT(width > 0 && width <= 0xFFFF);
 | 
	
		
			
				|  |  |      IM_ASSERT(height > 0 && height <= 0xFFFF);
 | 
	
		
			
				|  |  |      ImFontAtlasCustomRect r;
 | 
	
		
			
				|  |  | -    r.ID = id;
 | 
	
		
			
				|  |  |      r.Width = (unsigned short)width;
 | 
	
		
			
				|  |  |      r.Height = (unsigned short)height;
 | 
	
		
			
				|  |  |      CustomRects.push_back(r);
 | 
	
	
		
			
				|  | @@ -1848,13 +1844,16 @@ int ImFontAtlas::AddCustomRectRegular(unsigned int id, int width, int height)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  int ImFontAtlas::AddCustomRectFontGlyph(ImFont* font, ImWchar id, int width, int height, float advance_x, const ImVec2& offset)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | +#ifdef IMGUI_USE_WCHAR32
 | 
	
		
			
				|  |  | +    IM_ASSERT(id <= IM_UNICODE_CODEPOINT_MAX);
 | 
	
		
			
				|  |  | +#endif
 | 
	
		
			
				|  |  |      IM_ASSERT(font != NULL);
 | 
	
		
			
				|  |  |      IM_ASSERT(width > 0 && width <= 0xFFFF);
 | 
	
		
			
				|  |  |      IM_ASSERT(height > 0 && height <= 0xFFFF);
 | 
	
		
			
				|  |  |      ImFontAtlasCustomRect r;
 | 
	
		
			
				|  |  | -    r.ID = id;
 | 
	
		
			
				|  |  |      r.Width = (unsigned short)width;
 | 
	
		
			
				|  |  |      r.Height = (unsigned short)height;
 | 
	
		
			
				|  |  | +    r.GlyphID = id;
 | 
	
		
			
				|  |  |      r.GlyphAdvanceX = advance_x;
 | 
	
		
			
				|  |  |      r.GlyphOffset = offset;
 | 
	
		
			
				|  |  |      r.Font = font;
 | 
	
	
		
			
				|  | @@ -1879,7 +1878,6 @@ bool ImFontAtlas::GetMouseCursorTexData(ImGuiMouseCursor cursor_type, ImVec2* ou
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      IM_ASSERT(CustomRectIds[0] != -1);
 | 
	
		
			
				|  |  |      ImFontAtlasCustomRect& r = CustomRects[CustomRectIds[0]];
 | 
	
		
			
				|  |  | -    IM_ASSERT(r.ID == FONT_ATLAS_DEFAULT_TEX_DATA_ID);
 | 
	
		
			
				|  |  |      ImVec2 pos = FONT_ATLAS_DEFAULT_TEX_CURSOR_DATA[cursor_type][0] + ImVec2((float)r.X, (float)r.Y);
 | 
	
		
			
				|  |  |      ImVec2 size = FONT_ATLAS_DEFAULT_TEX_CURSOR_DATA[cursor_type][1];
 | 
	
		
			
				|  |  |      *out_size = size;
 | 
	
	
		
			
				|  | @@ -2214,9 +2212,9 @@ void ImFontAtlasBuildInit(ImFontAtlas* atlas)
 | 
	
		
			
				|  |  |      if (atlas->CustomRectIds[0] >= 0)
 | 
	
		
			
				|  |  |          return;
 | 
	
		
			
				|  |  |      if (!(atlas->Flags & ImFontAtlasFlags_NoMouseCursors))
 | 
	
		
			
				|  |  | -        atlas->CustomRectIds[0] = atlas->AddCustomRectRegular(FONT_ATLAS_DEFAULT_TEX_DATA_ID, FONT_ATLAS_DEFAULT_TEX_DATA_W_HALF*2+1, FONT_ATLAS_DEFAULT_TEX_DATA_H);
 | 
	
		
			
				|  |  | +        atlas->CustomRectIds[0] = atlas->AddCustomRectRegular(FONT_ATLAS_DEFAULT_TEX_DATA_W_HALF*2+1, FONT_ATLAS_DEFAULT_TEX_DATA_H);
 | 
	
		
			
				|  |  |      else
 | 
	
		
			
				|  |  | -        atlas->CustomRectIds[0] = atlas->AddCustomRectRegular(FONT_ATLAS_DEFAULT_TEX_DATA_ID, 2, 2);
 | 
	
		
			
				|  |  | +        atlas->CustomRectIds[0] = atlas->AddCustomRectRegular(2, 2);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void ImFontAtlasBuildSetupFont(ImFontAtlas* atlas, ImFont* font, ImFontConfig* font_config, float ascent, float descent)
 | 
	
	
		
			
				|  | @@ -2265,7 +2263,6 @@ static void ImFontAtlasBuildRenderDefaultTexData(ImFontAtlas* atlas)
 | 
	
		
			
				|  |  |      IM_ASSERT(atlas->CustomRectIds[0] >= 0);
 | 
	
		
			
				|  |  |      IM_ASSERT(atlas->TexPixelsAlpha8 != NULL);
 | 
	
		
			
				|  |  |      ImFontAtlasCustomRect& r = atlas->CustomRects[atlas->CustomRectIds[0]];
 | 
	
		
			
				|  |  | -    IM_ASSERT(r.ID == FONT_ATLAS_DEFAULT_TEX_DATA_ID);
 | 
	
		
			
				|  |  |      IM_ASSERT(r.IsPacked());
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      const int w = atlas->TexWidth;
 | 
	
	
		
			
				|  | @@ -2300,13 +2297,13 @@ void ImFontAtlasBuildFinish(ImFontAtlas* atlas)
 | 
	
		
			
				|  |  |      for (int i = 0; i < atlas->CustomRects.Size; i++)
 | 
	
		
			
				|  |  |      {
 | 
	
		
			
				|  |  |          const ImFontAtlasCustomRect& r = atlas->CustomRects[i];
 | 
	
		
			
				|  |  | -        if (r.Font == NULL || r.ID >= 0x110000)
 | 
	
		
			
				|  |  | +        if (r.Font == NULL || r.GlyphID == 0)
 | 
	
		
			
				|  |  |              continue;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          IM_ASSERT(r.Font->ContainerAtlas == atlas);
 | 
	
		
			
				|  |  |          ImVec2 uv0, uv1;
 | 
	
		
			
				|  |  |          atlas->CalcCustomRectUV(&r, &uv0, &uv1);
 | 
	
		
			
				|  |  | -        r.Font->AddGlyph((ImWchar)r.ID, r.GlyphOffset.x, r.GlyphOffset.y, r.GlyphOffset.x + r.Width, r.GlyphOffset.y + r.Height, uv0.x, uv0.y, uv1.x, uv1.y, r.GlyphAdvanceX);
 | 
	
		
			
				|  |  | +        r.Font->AddGlyph((ImWchar)r.GlyphID, r.GlyphOffset.x, r.GlyphOffset.y, r.GlyphOffset.x + r.Width, r.GlyphOffset.y + r.Height, uv0.x, uv0.y, uv1.x, uv1.y, r.GlyphAdvanceX);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // Build all fonts lookup tables
 | 
	
	
		
			
				|  | @@ -2316,7 +2313,7 @@ void ImFontAtlasBuildFinish(ImFontAtlas* atlas)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // Ellipsis character is required for rendering elided text. We prefer using U+2026 (horizontal ellipsis).
 | 
	
		
			
				|  |  |      // However some old fonts may contain ellipsis at U+0085. Here we auto-detect most suitable ellipsis character.
 | 
	
		
			
				|  |  | -    // FIXME: Also note that 0x2026 is currently seldomly included in our font ranges. Because of this we are more likely to use three individual dots.
 | 
	
		
			
				|  |  | +    // FIXME: Also note that 0x2026 is currently seldom included in our font ranges. Because of this we are more likely to use three individual dots.
 | 
	
		
			
				|  |  |      for (int i = 0; i < atlas->Fonts.size(); i++)
 | 
	
		
			
				|  |  |      {
 | 
	
		
			
				|  |  |          ImFont* font = atlas->Fonts[i];
 | 
	
	
		
			
				|  | @@ -3366,7 +3363,7 @@ void ImGui::RenderRectFilledWithHole(ImDrawList* draw_list, ImRect outer, ImRect
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  // Helper for ColorPicker4()
 | 
	
		
			
				|  |  |  // NB: This is rather brittle and will show artifact when rounding this enabled if rounded corners overlap multiple cells. Caller currently responsible for avoiding that.
 | 
	
		
			
				|  |  | -// Spent a non reasonable amount of time trying to getting this right for ColorButton with rounding+anti-aliasing+ImGuiColorEditFlags_HalfAlphaPreview flag + various grid sizes and offsets, and eventually gave up... probably more reasonable to disable rounding alltogether.
 | 
	
		
			
				|  |  | +// Spent a non reasonable amount of time trying to getting this right for ColorButton with rounding+anti-aliasing+ImGuiColorEditFlags_HalfAlphaPreview flag + various grid sizes and offsets, and eventually gave up... probably more reasonable to disable rounding altogether.
 | 
	
		
			
				|  |  |  // FIXME: uses ImGui::GetColorU32
 | 
	
		
			
				|  |  |  void ImGui::RenderColorRectWithAlphaCheckerboard(ImDrawList* draw_list, ImVec2 p_min, ImVec2 p_max, ImU32 col, float grid_step, ImVec2 grid_off, float rounding, int rounding_corners_flags)
 | 
	
		
			
				|  |  |  {
 |