cutter/src/dialogs/LinkTypeDialog.h

64 lines
1.8 KiB
C
Raw Normal View History

#ifndef LINKTYPEDIALOG_H
#define LINKTYPEDIALOG_H
#include "core/Cutter.h"
#include <QDialog>
namespace Ui {
class LinkTypeDialog;
}
class LinkTypeDialog : public QDialog
{
Q_OBJECT
public:
explicit LinkTypeDialog(QWidget *parent = nullptr);
~LinkTypeDialog();
2019-03-06 20:30:39 +00:00
/**
* @brief Sets the default type which will be displayed in the combo box
* @param type Default type to be used as default type
*/
void setDefaultType(const QString &type);
2019-03-06 20:30:39 +00:00
/**
* @brief Sets the value of the default address which will be displayed
* If the given address is linked to a type, then it also sets the default
* type to the currently linked type
2019-03-06 20:30:39 +00:00
* @param address The address to be used as default address
*/
void setDefaultAddress(QString address);
private slots:
2019-03-06 20:30:39 +00:00
/**
* @brief Overrides the done() method of QDialog
* On clicking the Ok button, it links a valid address to a type.
* If "(No Type)" is selected as type, it removes the link.
* In case of an invalid address, it displays error message
2019-03-06 20:30:39 +00:00
* @param r The value which will be returned by exec()
*/
void done(int r) override;
2019-03-06 20:30:39 +00:00
/**
* @brief Executed whenever the text inside exprLineEdit changes
* If expression evaluates to valid address, it is displayed in addressLineEdit
* Otherwise "Invalid Address" is shown in addressLineEdit
2019-03-06 20:30:39 +00:00
* @param text The current value of exprLineEdit
*/
void on_exprLineEdit_textChanged(const QString &text);
private:
Ui::LinkTypeDialog *ui;
2019-03-06 20:30:39 +00:00
/**
* @brief Used for finding the type which is linked to the given address
* @param address
* @return The type linked to "address" if it exists, or empty string otherwise
*/
QString findLinkedType(RVA address);
};
#endif // LINKTYPEDIALOG_H