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 235 236 237 238 239 240 241 242
|
/****************************************************************************
** 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 ASSEMBLER_H
#define ASSEMBLER_H
#include <QObject>
#include <QMap>
#include <QList>
#include <QRegExp>
#include <QFile>
#include <QTextStream>
#include <QVector>
#include <QTextCharFormat>
#include <QSettings>
#include <QPalette>
#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).
*/
|