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
|
/****************************************************************************
** 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/>.)
**
****************************************************************************/
#include "highlighter.h"
/**
* @file highlighter.cpp
* The code highlighting features are defined here.
*/
Highlighter::Highlighter(Assembler *assembler, QTextDocument *parent)
: QSyntaxHighlighter(parent)
{
QTextCharFormat keywordFormat;
QTextCharFormat quotationFormat;
QTextCharFormat registerFormat;
QTextCharFormat labelFormat;
QTextCharFormat labelWithDotFormat;
QTextCharFormat memoryFormat;
QTextCharFormat systemFormat;
QTextCharFormat numberFormat;
QTextCharFormat iomacrosFormat;
QList<QColor> defaultColors;
QList<QString> names;
QList<QTextCharFormat *> formats;
//setting up text formats
names << "keywords" << "registers" << "numbers" << "memory" <<
"labels" << "comments" << "system" << "iomacro" <<
"quotation";
defaultColors << QColor(Qt::blue) << QColor(153, 0, 204) << //according to colorNames
QColor(255, 122, 0) << QColor(0, 128, 255) <<
QColor(128, 0, 0) << QColor(Qt::darkGreen) <<
QColor(Qt::darkCyan) << QColor(Qt::blue) <<
QColor(128, 128, 128);
formats << &keywordFormat << ®isterFormat << &numberFormat << &memoryFormat <<
&labelFormat << &commentFormat << &systemFormat << &iomacrosFormat <<
"ationFormat;
QSettings settings("SASM Project", "SASM");
for (int i = 0; i < formats.size(); i++) {
formats[i]->setForeground(settings.value(names[i] + "color", defaultColors[i]).value<QColor>());
formats[i]->setBackground(settings.value(names[i] + "colorbg", QPalette().color(QPalette::Base)).value<QColor>());
if (settings.value(names[i] + "bold", (i == 0) ? true : false).toBool())
formats[i]->setFontWeight(QFont::Bold);
formats[i]->setFontItalic(settings.value(names[i] + "italic", false).toBool());
}
labelWithDotFormat.setForeground(settings.value("fontcolor", QPalette().color(QPalette::WindowText)).value<QColor>());
formats << &labelWithDotFormat;
assembler->fillHighligherRules(highlightingRules, formats, multiLineComments, commentStartExpression, commentEndExpression);
}
void Highlighter::highlightBlock(const QString &text)
{
foreach (const HighlightingRule &rule, highlightingRules) {
QRegExp expression(rule.pattern);
int index = expression.indexIn(text);
while (index >= 0) {
int length = expression.matchedLength();
if (rule.isComment) {
if (!isCommentInQuote(text, index)) {
setFormat(index, length, rule.format);
index = expression.indexIn(text, index + length);
} else {
index = expression.indexIn(text, index + 1);
}
} else {
setFormat(index, length, rule.format);
index = expression.indexIn(text, index + length);
}
}
}
if (multiLineComments) {
setCurrentBlockState(0);
int startIndex = 0;
if (previousBlockState() != 1) {
startIndex = commentStartExpression.indexIn(text);
if (startIndex != -1 && isCommentInQuote(text, startIndex)) {
startIndex = -1;
}
}
while (startIndex >= 0) {
int endIndex = commentEndExpression.indexIn(text, startIndex);
int commentLength;
if (endIndex == -1) {
setCurrentBlockState(1);
commentLength = text.length() - startIndex;
} else {
commentLength = endIndex - startIndex
+ commentEndExpression.matchedLength();
}
setFormat(startIndex, commentLength, commentFormat);
startIndex = commentStartExpression.indexIn(text, startIndex + commentLength);
}
}
}
bool Highlighter::isCommentInQuote(const QString &text, int index)
{
bool inQuote = false;
char quote = 0;
for (int i = 0; i < index; ++i) {
char c = text[i].toLatin1();
switch (c) {
case '"':
case '\'':
case '`':
if (!inQuote) {
inQuote = true;
quote = c;
} else if (quote == c) {
inQuote = false;
}
}
}
return inQuote;
}
Highlighter::~Highlighter()
{
highlightingRules.clear();
}
|