Skip to content

Commit

Permalink
Fixed file name display in new file dialog (radareorg#1675)
Browse files Browse the repository at this point in the history
  • Loading branch information
xarkes authored Jul 31, 2019
1 parent a5dc85c commit 148c7aa
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 19 deletions.
4 changes: 2 additions & 2 deletions src/core/CutterCommon.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@
#include <QString>

// Workaround for compile errors on Windows
#ifdef _WIN32
#ifdef Q_OS_WIN
#undef min
#undef max
#endif //_WIN32
#endif // Q_OS_WIN

// radare2 list iteration macros
#define CutterRListForeach(list, it, type, x) \
Expand Down
41 changes: 24 additions & 17 deletions src/dialogs/NewFileDialog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ static QColor getColorFor(int pos)
QColor(231, 76, 60), // Red
QColor(243, 156, 17) // Orange
};
return colors[pos % 6];
return colors[pos % colors.size()];
}

static QIcon getIconFor(const QString &str, int pos)
Expand All @@ -43,7 +43,10 @@ static QIcon getIconFor(const QString &str, int pos)
pixPaint.setBrush(getColorFor(pos));
pixPaint.drawEllipse(1, 1, w - 2, h - 2);
pixPaint.setPen(Qt::white);
pixPaint.setFont(QFont("Verdana", 24, 1));
QFont font = Config()->getFont();
font.setBold(true);
font.setPointSize(18);
pixPaint.setFont(font);
pixPaint.drawText(0, 0, w, h - 2, Qt::AlignCenter, QString(str).toUpper().mid(0, 2));
return QIcon(pixmap);
}
Expand Down Expand Up @@ -87,7 +90,8 @@ void NewFileDialog::on_loadFileButton_clicked()
void NewFileDialog::on_selectFileButton_clicked()
{
QString currentDir = Config()->getRecentFolder();
const QString &fileName = QDir::toNativeSeparators(QFileDialog::getOpenFileName(this, tr("Select file"), currentDir));
const QString &fileName = QDir::toNativeSeparators(QFileDialog::getOpenFileName(this,
tr("Select file"), currentDir));

if (!fileName.isEmpty()) {
ui->newFileEdit->setText(fileName);
Expand All @@ -104,8 +108,8 @@ void NewFileDialog::on_selectProjectsDirButton_clicked()
currentDir = QDir::homePath() + currentDir.mid(1);
}
const QString &dir = QDir::toNativeSeparators(QFileDialog::getExistingDirectory(this,
tr("Select project path (dir.projects)"),
currentDir));
tr("Select project path (dir.projects)"),
currentDir));

if (dir.isEmpty()) {
return;
Expand Down Expand Up @@ -271,24 +275,27 @@ bool NewFileDialog::fillRecentFilesList()
QMutableListIterator<QString> it(files);
int i = 0;
while (it.hasNext()) {
const QString &file = QDir::toNativeSeparators(it.next());
// Get stored files

// Remove all but the file name
const QString name = file.section(QDir::separator(), -1);

// Get the file name
const QString &fullpath = QDir::toNativeSeparators(it.next());
const QString homepath = QDir::homePath();
const QString basename = fullpath.section(QDir::separator(), -1);
QString filenameHome = fullpath;
filenameHome.replace(homepath, "~");
filenameHome.replace(basename, "");
filenameHome.chop(1); // Remove last character that will be a path separator
// Get file info
QFileInfo info(file);
QFileInfo info(fullpath);
if (!info.exists()) {
it.remove();
} else {
// Format the text and add the item to the file list
const QString text = QString("%1\n%2\nSize: %3").arg(basename, filenameHome,
qhelpers::formatBytecount(info.size()));
QListWidgetItem *item = new QListWidgetItem(
getIconFor(name, i++),
file + "\nCreated: " + info.birthTime().toString() + "\nSize: " + qhelpers::formatBytecount(
info.size())
getIconFor(basename, i++),
text
);
//":/img/icons/target.svg"), name );
item->setData(Qt::UserRole, file);
item->setData(Qt::UserRole, fullpath);
ui->recentsListWidget->addItem(item);
}
}
Expand Down

0 comments on commit 148c7aa

Please sign in to comment.