-
Notifications
You must be signed in to change notification settings - Fork 196
/
Copy pathassembler.h
241 lines (200 loc) · 8.42 KB
/
assembler.h
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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
/****************************************************************************
** SASM - simple IDE for assembler development
** Copyright (C) 2013 Dmitriy Manushin
** Contact: site: http://dman95.github.io/SASM/
** e-mail: [email protected]
**
** 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 ASSEMBLER_H
#define ASSEMBLER_H
#include <QObject>
#include <QMap>
#include <QList>
#include <QRegExp>
#include <QFile>
#include <QTextStream>
#include <QVector>
#include <QTextCharFormat>
#include <QSettings>
#include "common.h"
#include "codeeditor.h"
/**
* @file assembler.h
* Base class for creating assembler instances
*/
/*! \brief This is the base class that all assemblers inherit
*
* The Assembler class contains functions which can be used to retrieve assember specific
* parameters such as the linker & assembler location, the default program text, and
* user specified options.
*
*/
class Assembler : public QObject
{
Q_OBJECT
public:
/*!
* \brief Struct for setting correspondence between
* program text line numbers and addresses in memory
*/
struct LineNum {
//! Program text line number
quint64 numInCode;
//! Address of instruction on this line in memory
quint64 numInMem;
bool operator ==(const LineNum& ln)
{
return ln.numInCode == numInCode;
}
};
/*!
* \brief Struct for setting pattern's highlighting rules
*/
struct HighlightingRule
{
HighlightingRule() : isComment(false) {
}
//! Pattern to highlight
QRegExp pattern;
//! Highlighting format - foreground color, background color, bold style and etc.
QTextCharFormat format;
bool isComment;
};
bool x86;
//! Assembler constructor. Note that this is the stage where x86 is determined.
explicit Assembler(bool x86, QObject *parent = 0);
//! Return the default path to the assembler.
virtual QString getAssemblerPath() = 0;
//! Returns the default path to the linker.
virtual QString getLinkerPath() = 0;
/*!
* \brief Get entry point offset in object file.
* \param lst listing file
* \param entryLabel entry point label name - main or start
* \return entry point address in object file
*/
virtual quint64 getMainOffset(QFile &lst, QString entryLabel) = 0;
/*!
* \brief Parses the listing file \a lst and fills vector \a lines with results of parsing
* \param lst listing file
* \param lines vector with info to fill
* \param offset difference between address of instruction in object file
* and address of instruction in memory
*/
virtual void parseLstFile(QFile &lst,
QVector<Assembler::LineNum> &lines,
quint64 offset) = 0;
/*!
* \brief Sets highlighting for assembly listing
* \param highlightingRules highlighting rules to fill
* \param formats formats for different types of highlighted expressions
* (see NASM, MASM, FASM, GAS as examples)
* \param multiLineComments is needed to support multiline comments
* \param commentStartExpression multiline comment start ("/" + "*" in C for example)
* \param commentEndExpression multiline comment end ("*" + "/" in C for example)
*/
virtual void fillHighligherRules(QVector<Assembler::HighlightingRule> &highlightingRules,
QList<QTextCharFormat *> &formats,
bool &multiLineComments,
QRegExp &commentStartExpression,
QRegExp &commentEndExpression) = 0;
//! Returns the default start text (default project code)
virtual QString getStartText() = 0;
//! Puts the debug string that makes frame (mov ebp, esp)
virtual void putDebugString(CodeEditor *code) = 0;
//! Returns the default assembler options
virtual QString getAssemblerOptions() = 0;
//! Returns the default linker options
virtual QString getLinkerOptions() = 0;
//! Determines if the system is x86
bool isx86();
signals:
public slots:
};
#endif // ASSEMBLER_H
/*! \mainpage SASM Dev Guide
*
* \section intro_sec Introduction
*
* Below you will find what and where to modify appropriate header and source files when you want to add a feature.
*
* \section section1 Commenting
*
* When commenting use doxygen's syntax. Place the comment above the intended line. After adding the feature, run
* doxygen.exe configfile to update the documentation. Be sure to double check the documentation to ensure the
* added comments were parsed correctly.
*
* \section section2 Adding Assembler Support
*
* Adding support is a relatively straight forward process. Each supported assembler is a derived Assembler and
* has its own header and cpp file.
*
* \subsection step1 Step 1: Creating the header and cpp
*
* The first step is to create the new header and cpp file for the assembler. These should be named all lowercase without gaps
*
* \subsection step2 Step 2: Creating the assembler class
*
* The decleration of the class may best be discussed in light of already supported assemblers. Take for example, NASM. The NASM
* class is defined as:
* class NASM : public Assembler
*
* The generic definition is
* class YOURASSEMBLER : public Assembler
*
* The variables and methods of YOURASSEMBLER should be the virtual methods of Assembler. If you are unsure what to add, refer to
* the already supported assemler classes. You may copy and paste them.
*
* \subsection step3 Step 3: Adding it to the Build Options
*
* You should hopefully know enough QT to be able to add form controls. The code for modifying the build menu can be found in
* mainwindow.cpp. Refer to its documentation for more reference on where to add/modify code.
*
* \section section3 Adding Language Support
*
*
* \subsection help Help File
*
* The help file, helpENG.html, needs to be translated and saved into a new help<NEW LANGUAGE>.html file.
* The
* void MainWindow::openHelp()
* must be modified to support the added language. This is done by adding another if statement.
*
* \subsection interface Interface language
*
* New language_<new language>.ts file needs to be created and filled with translations using Qt Linguist.
* Compiled language_<new language>.qm and qt_<new_language>.qm files need to be added in SASM folder.
* Support of new language needs to be added in settings (mainwindow.cpp) and in loading code (main.cpp).
*/