146 lines
5.2 KiB
C++
146 lines
5.2 KiB
C++
/*
|
|
* Copyright (C) 2020-2022 Roy Qu (royqh1979@gmail.com)
|
|
*
|
|
* This program 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.
|
|
*
|
|
* This program 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 this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef MISCPROCS_H
|
|
#define MISCPROCS_H
|
|
#include <QPoint>
|
|
#include <vector>
|
|
#include <memory>
|
|
#include <QString>
|
|
#include <QSet>
|
|
#include "highlighter/base.h"
|
|
#include <QPaintDevice>
|
|
#include <QTextStream>
|
|
#include <QVector>
|
|
#include <initializer_list>
|
|
//#include <QRect>
|
|
//#include <QColor>
|
|
|
|
class QPainter;
|
|
class QRect;
|
|
class QColor;
|
|
|
|
using IntArray = QVector<int>;
|
|
using PIntArray = std::shared_ptr<IntArray>;
|
|
|
|
int minMax(int x, int mi, int ma);
|
|
int mulDiv(int a, int b, int c);
|
|
void swapInt(int& l, int &r);
|
|
BufferCoord maxBufferCoord(const BufferCoord& P1, const BufferCoord& P2);
|
|
BufferCoord minBufferCoord(const BufferCoord& P1, const BufferCoord& P2);
|
|
QPoint maxPoint(const QPoint& P1, const QPoint& P2);
|
|
QPoint minPoint(const QPoint& P1, const QPoint& P2);
|
|
|
|
PIntArray getIntArray(size_t Count, int InitialValue);
|
|
|
|
void internalFillRect(QPainter* painter, const QRect& rcPaint, const QColor& color);
|
|
|
|
// Converting tabs to spaces: To use the function several times it's better
|
|
// to use a function pointer that is set to the fastest conversion function.
|
|
using ConvertTabsProc = std::function<QString(const QString&, int)>;
|
|
|
|
ConvertTabsProc GetBestConvertTabsProc(int TabWidth);
|
|
|
|
// This is the slowest conversion function which can handle TabWidth <> 2^n.
|
|
QString ConvertTabs(const QString& Line, int TabWidth);
|
|
|
|
using ConvertTabsProcEx = std::function<QString(const QString&, int, bool& )>;
|
|
|
|
ConvertTabsProcEx GetBestConvertTabsProcEx(int TabWidth);
|
|
// This is the slowest conversion function which can handle TabWidth <> 2^n.
|
|
QString ConvertTabsEx(const QString& Line, int TabWidth, bool& HasTabs);
|
|
|
|
bool GetHasTabs(const QString& line, int& CharsBefore);
|
|
|
|
int GetExpandedLength(const QString& aStr, int aTabWidth);
|
|
|
|
int CharIndex2CaretPos(int Index, int TabWidth,
|
|
const QString& Line);
|
|
|
|
int CaretPos2CharIndex(int Position, int TabWidth, const QString& Line,
|
|
bool& InsideTabChar);
|
|
|
|
// search for the first char of set AChars in Line, starting at index Start
|
|
int StrScanForCharInSet(const QString& Line, int Start, const QSet<QChar>& AChars);
|
|
// the same, but searching backwards
|
|
int StrRScanForCharInSet(const QString& Line, int Start, const QSet<QChar>& AChars);
|
|
|
|
int GetEOL(const QString& Line, int start);
|
|
int CountLines(const QString& Line, int start);
|
|
|
|
QStringList splitStrings(const QString& text);
|
|
|
|
// Remove all '/' characters from string by changing them into '\.'.
|
|
// Change all '\' characters into '\\' to allow for unique decoding.
|
|
QString EncodeString(const QString & s);
|
|
|
|
// Decodes string, encoded with EncodeString.
|
|
QString DecodeString(const QString& s);
|
|
|
|
using HighlighterAttriProc = std::function<bool(PSynHighlighter Highlighter,
|
|
PSynHighlighterAttribute Attri, const QString& UniqueAttriName,
|
|
QList<void *> Params)>;
|
|
|
|
// Enums all child highlighters and their attributes of a TSynMultiSyn through a
|
|
// callback function.
|
|
// This function also handles nested TSynMultiSyns including their MarkerAttri.
|
|
bool EnumHighlighterAttris(PSynHighlighter Highlighter,
|
|
bool SkipDuplicates, HighlighterAttriProc highlighterAttriProc,
|
|
std::initializer_list<void *> Params);
|
|
|
|
|
|
// Calculates Frame Check Sequence (FCS) 16-bit Checksum (as defined in RFC 1171)
|
|
uint16_t CalcFCS(unsigned char* ABuf, int ABufSize);
|
|
|
|
void SynDrawGradient(QPaintDevice* ACanvas, const QColor& AStartColor, const QColor& AEndColor,
|
|
int ASteps, const QRect& ARect, bool AHorizontal);
|
|
|
|
SynFontStyles getFontStyles(const QFont& font);
|
|
|
|
/**
|
|
* Find the first occurency of word char in s, starting from startPos
|
|
* Note: the index of first char in s in 1
|
|
* @return index of the char founded , 0 if not found
|
|
*/
|
|
int StrScanForWordChar(const QString& s, int startPos);
|
|
|
|
/**
|
|
* Find the first occurency of non word char in s, starting from startPos
|
|
* Note: the index of first char in s in 1
|
|
* @return index of the char founded , 0 if not found
|
|
*/
|
|
int StrScanForNonWordChar(const QString& s, int startPos);
|
|
|
|
/**
|
|
* Find the first occurency of word char in s right to left, starting from startPos
|
|
* Note: the index of first char in s in 1
|
|
* @return index of the char founded , 0 if not found
|
|
*/
|
|
int StrRScanForWordChar(const QString& s, int startPos);
|
|
|
|
/**
|
|
* Find the first occurency of non word char in s right to left, starting from startPos
|
|
* Note: the index of first char in s in 1
|
|
* @return index of the char founded , 0 if not found
|
|
*/
|
|
int StrRScanForNonWordChar(const QString& s, int startPos);
|
|
|
|
void ensureNotAfter(BufferCoord& cord1, BufferCoord& cord2);
|
|
|
|
bool isWordChar(const QChar& ch);
|
|
|
|
#endif // MISCPROCS_H
|