Fix and simplify get_file_name

This function created a QFile that it didn't need and it returned a
dangling pointer (the std::string object was destroyed at the end of the
function).

The function now returns a pointer that the caller must free. For that
reason, it's easier in copy_image_and_overwrite to just go for the
QFileInfo call.

Signed-off-by: Thiago Macieira <thiago@macieira.org>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
Thiago Macieira 2014-08-17 10:42:47 -07:00 committed by Dirk Hohndel
parent 29f50c6aee
commit f3d44db512
3 changed files with 8 additions and 8 deletions

View file

@ -284,19 +284,17 @@ picture_load_exit:
return;
}
extern "C" const char* get_file_name(const char *fileName)
extern "C" char *get_file_name(const char *fileName)
{
QFile file(fileName);
QFileInfo fileInfo(file.fileName());
QString filename(fileInfo.fileName());
return filename.toStdString().c_str();
QFileInfo fileInfo(fileName);
return strdup(fileInfo.fileName().toUtf8());
}
extern "C" void copy_image_and_overwrite(const char *cfileName, const char *cnewName)
{
QString fileName = QString::fromUtf8(cfileName);
QString newName = QString::fromUtf8(cnewName);
newName += get_file_name(cfileName);
newName += QFileInfo(cfileName).fileName();
QFile file(newName);
if (file.exists())
file.remove();