Skip to content

Commit

Permalink
Fix crashes on building or tech sprites
Browse files Browse the repository at this point in the history
Create a dummy "error" pixmap when the sprites are missing.
  • Loading branch information
lmoureaux committed Nov 23, 2023
1 parent b1a8bba commit 41744f6
Showing 1 changed file with 18 additions and 9 deletions.
27 changes: 18 additions & 9 deletions client/tilespec.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1147,14 +1147,22 @@ void tilespec_reread_frozen_refresh(const QString &name)
menus_init();
}

/**
* Makes a dummy "error" pixmap to prevent crashes.
*/
static QPixmap *make_error_pixmap()
{
auto s = new QPixmap(20, 20);
s->fill(Qt::red);
return s;
}

/**
Loads the given graphics file (found in the data path) into a newly
allocated sprite.
*/
static QPixmap *load_gfx_file(const char *gfx_filename)
{
QPixmap *s;

// Try out all supported file extensions to find one that works.
auto supported = QImageReader::supportedImageFormats();

Expand All @@ -1172,17 +1180,14 @@ static QPixmap *load_gfx_file(const char *gfx_filename)
if (!real_full_name.isEmpty()) {
log_debug("trying to load gfx file \"%s\".",
qUtf8Printable(real_full_name));
s = load_gfxfile(qUtf8Printable(real_full_name));
if (s) {
if (const auto s = load_gfxfile(qUtf8Printable(real_full_name)); s) {
return s;
}
}
}

qCritical("Could not load gfx file \"%s\".", gfx_filename);
s = new QPixmap(20, 20);
s->fill(Qt::red);
return s;
return make_error_pixmap();
}

/**
Expand Down Expand Up @@ -3131,7 +3136,9 @@ void tileset_setup_impr_type(struct tileset *t, struct impr_type *pimprove)
pimprove->graphic_alt, "improvement",
improvement_rule_name(pimprove), false);

// should maybe do something if nullptr, eg generic default?
if (!t->sprites.building[improvement_index(pimprove)]) {
t->sprites.building[improvement_index(pimprove)] = make_error_pixmap();
}
}

/**
Expand All @@ -3145,7 +3152,9 @@ void tileset_setup_tech_type(struct tileset *t, struct advance *padvance)
t, LOG_VERBOSE, padvance->graphic_str, padvance->graphic_alt,
"technology", advance_rule_name(padvance), false);

// should maybe do something if nullptr, eg generic default?
if (!t->sprites.tech[advance_index(padvance)]) {
t->sprites.tech[advance_index(padvance)] = make_error_pixmap();
}
} else {
t->sprites.tech[advance_index(padvance)] = nullptr;
}
Expand Down

0 comments on commit 41744f6

Please sign in to comment.