Skip to content

Commit

Permalink
Fix several instances of possible vertex overflow
Browse files Browse the repository at this point in the history
  • Loading branch information
GinjaNinja32 committed Sep 20, 2024
1 parent 033ee44 commit 1086513
Showing 1 changed file with 22 additions and 5 deletions.
27 changes: 22 additions & 5 deletions src/graphics/renderTarget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -487,6 +487,14 @@ void RenderTarget::drawTiled(const sp::Rect& rect, std::string_view texture, glm
{
for(int y=0; y<tile_count.y; y++)
{
if(vertex_data.size() >= std::numeric_limits<uint64_t>::max() - 4)
{
if (info.texture)
finish(info.texture);
else
finish();
}

auto n = vertex_data.size();
index_data.insert(index_data.end(), {
uint16_t(n + 0), uint16_t(n + 1), uint16_t(n + 2),
Expand Down Expand Up @@ -600,6 +608,9 @@ void RenderTarget::fillCircle(glm::vec2 center, float radius, glm::u8vec4 color)

void RenderTarget::fillRect(const sp::Rect& rect, glm::u8vec4 color)
{
if (vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 4)
finish();

auto n = vertex_data.size();
index_data.insert(index_data.end(), {
uint16_t(n + 0), uint16_t(n + 1), uint16_t(n + 2),
Expand All @@ -622,7 +633,7 @@ void RenderTarget::drawTexturedQuad(std::string_view texture,
glm::u8vec4 color)
{
auto info = getTextureInfo(texture);
if (info.texture)
if (info.texture || vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 4)
finish();
auto& uv_rect = info.uv_rect;

Expand Down Expand Up @@ -747,6 +758,9 @@ void RenderTarget::drawText(sp::Rect rect, const sp::Font::PreparedFontString& p
p2 += rect.position;
p3 += rect.position;

if (vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 4)
finish();

auto n = vertex_data.size();
index_data.insert(index_data.end(), {
uint16_t(n + 0), uint16_t(n + 1), uint16_t(n + 2),
Expand Down Expand Up @@ -815,6 +829,9 @@ void RenderTarget::drawRotatedText(glm::vec2 center, float rotation, std::string
glm::vec2 p2 = mat * glm::vec2{left, bottom} + center;
glm::vec2 p3 = mat * glm::vec2{right, bottom} + center;

if (vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 4)
finish();

auto n = vertex_data.size();
index_data.insert(index_data.end(), {
uint16_t(n + 0), uint16_t(n + 1), uint16_t(n + 2),
Expand Down Expand Up @@ -845,7 +862,7 @@ void RenderTarget::drawStretched(sp::Rect rect, std::string_view texture, glm::u
void RenderTarget::drawStretchedH(sp::Rect rect, std::string_view texture, glm::u8vec4 color)
{
auto info = getTextureInfo(texture);
if (info.texture)
if (info.texture || vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 8)
finish();
auto& uv_rect = info.uv_rect;

Expand Down Expand Up @@ -894,7 +911,7 @@ void RenderTarget::drawStretchedH(sp::Rect rect, std::string_view texture, glm::
void RenderTarget::drawStretchedV(sp::Rect rect, std::string_view texture, glm::u8vec4 color)
{
auto info = getTextureInfo(texture);
if (info.texture)
if (info.texture || vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 8)
finish();
auto& uv_rect = info.uv_rect;

Expand Down Expand Up @@ -943,7 +960,7 @@ void RenderTarget::drawStretchedV(sp::Rect rect, std::string_view texture, glm::
void RenderTarget::drawStretchedHV(sp::Rect rect, float corner_size, std::string_view texture, glm::u8vec4 color)
{
auto info = getTextureInfo(texture);
if (info.texture)
if (info.texture || vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 16)
finish();
auto& uv_rect = info.uv_rect;

Expand Down Expand Up @@ -1035,7 +1052,7 @@ void RenderTarget::drawStretchedHVClipped(sp::Rect rect, sp::Rect clip_rect, flo
return;

auto info = getTextureInfo(texture);
if (info.texture)
if (info.texture || vertex_data.size() >= std::numeric_limits<uint16_t>::max() - 16)
finish();
const auto& uv_rect = info.uv_rect;

Expand Down

0 comments on commit 1086513

Please sign in to comment.