1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
|
/****************************************************************************
** SASM - simple IDE for assembler development
** Copyright (C) 2013 Dmitriy Manushin
** Contact: site: http://dman95.github.io/SASM/
** e-mail: Dman1095@gmail.com
**
** This file is part of SASM.
**
** SASM is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation, either version 3 of the License, or
** (at your option) any later version.
**
** SASM is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with SASM. If not, see <http://www.gnu.org/licenses/>.
**
** Этот файл — часть SASM.
**
** SASM - свободная программа: вы можете перераспространять ее и/или
** изменять ее на условиях Стандартной общественной лицензии GNU в том виде,
** в каком она была опубликована Фондом свободного программного обеспечения;
** либо версии 3 лицензии, либо (по вашему выбору) любой более поздней
** версии.
**
** SASM распространяется в надежде, что она будет полезной,
** но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
** или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Стандартной
** общественной лицензии GNU.
**
** Вы должны были получить копию Стандартной общественной лицензии GNU
** вместе с этой программой. Если это не так, см.
** <http://www.gnu.org/licenses/>.)
**
****************************************************************************/
#ifndef RUQPLAINTEXTEDIT_H
#define RUQPLAINTEXTEDIT_H
#include <QPlainTextEdit>
#include <QAction>
#include <QMenu>
#include <QContextMenuEvent>
#include <QTextBlock>
#include <QTextStream>
#include <QPointer>
#include <QSettings>
#include "common.h"
/**
* @file ruqplaintextedit.h
* Text editor base class definition file.
*/
/*! \brief This defines the base class which the text editor is derived from.
*
* The class contains methods that are used in the editor. These range from simple
* copying and pasting to enabling/disabling the debugger.
*/
class RuQPlainTextEdit : public QPlainTextEdit
{
Q_OBJECT
public:
//! The class constructor creates the editor, given a specified parent QWidget object.
RuQPlainTextEdit(QWidget *parent = 0);
~RuQPlainTextEdit();
//! Creates a menu
QMenu *createMenu();
//! Defines a structure to keep track of a watched variable.
struct Watch {
QString name;
int type;
int size;
int arraySize;
bool address;
};
protected:
void contextMenuEvent(QContextMenuEvent *e);
private:
RuQPlainTextEdit::Watch variableOnCurrentLine();
QPointer<QMenu> contextMenu;
//! Creates a comment
QAction *commentAction;
//! Removes a comment
QAction *uncommentAction;
//! Undo the last action
QAction *undoAction;
//! Do the previous action again.
QAction *redoAction;
//! Cut a selected text string.
QAction *cutAction;
//! Copy a selected text string.
QAction *copyAction;
//! Paste the clipboard contents.
QAction *pasteAction;
//! Delete a selected text string.
QAction *deleteAction;
//! Select all of the text.
QAction *selectAllAction;
//! Add a watch on a variable.
QAction *addWatchAction;
//! Used to keep track if the debugger is enabled.
bool debugEnabled;
public slots:
//! Method that comments the user selected code.
void commentSelectedCode();
//! Method for uncommenting a previously commented code block.
void uncommentSelectedCode();
void deleteSelected();
//! Method for adding a variable watch.
void addWatch();
//! Used to enable the debugger.
void setDebugEnabled();
//! Used to disable the debugger.
void setDebugDisabled();
signals:
//! Signal which emited when watch variable action is selected.
void addWatchSignal(RuQPlainTextEdit::Watch variable);
};
#endif // RUQPLAINTEXTEDIT_H
|