2010-08-22 01:59:56 +02:00
|
|
|
// Scintilla source code edit control
|
2019-05-04 20:14:48 +02:00
|
|
|
/** @file Accessor.cxx
|
|
|
|
** Interfaces between Scintilla and lexers.
|
2010-08-22 01:59:56 +02:00
|
|
|
**/
|
|
|
|
// Copyright 1998-2002 by Neil Hodgson <neilh@scintilla.org>
|
|
|
|
// The License.txt file describes the conditions under which this software may be distributed.
|
|
|
|
|
2019-05-04 20:14:48 +02:00
|
|
|
#include <cstdlib>
|
|
|
|
#include <cassert>
|
2010-08-22 01:59:56 +02:00
|
|
|
|
|
|
|
#include "ILexer.h"
|
|
|
|
#include "Scintilla.h"
|
|
|
|
#include "SciLexer.h"
|
|
|
|
|
|
|
|
#include "PropSetSimple.h"
|
|
|
|
#include "WordList.h"
|
|
|
|
#include "LexAccessor.h"
|
|
|
|
#include "Accessor.h"
|
|
|
|
|
|
|
|
using namespace Scintilla;
|
|
|
|
|
|
|
|
Accessor::Accessor(IDocument *pAccess_, PropSetSimple *pprops_) : LexAccessor(pAccess_), pprops(pprops_) {
|
|
|
|
}
|
|
|
|
|
2013-08-28 02:44:27 +02:00
|
|
|
int Accessor::GetPropertyInt(const char *key, int defaultValue) const {
|
2010-08-22 01:59:56 +02:00
|
|
|
return pprops->GetInt(key, defaultValue);
|
|
|
|
}
|
|
|
|
|
2019-05-04 20:14:48 +02:00
|
|
|
int Accessor::IndentAmount(Sci_Position line, int *flags, PFNIsCommentLeader pfnIsCommentLeader) {
|
|
|
|
const Sci_Position end = Length();
|
2010-08-22 01:59:56 +02:00
|
|
|
int spaceFlags = 0;
|
|
|
|
|
|
|
|
// Determines the indentation level of the current line and also checks for consistent
|
|
|
|
// indentation compared to the previous line.
|
|
|
|
// Indentation is judged consistent when the indentation whitespace of each line lines
|
|
|
|
// the same or the indentation of one line is a prefix of the other.
|
|
|
|
|
2019-05-04 20:14:48 +02:00
|
|
|
Sci_Position pos = LineStart(line);
|
2010-08-22 01:59:56 +02:00
|
|
|
char ch = (*this)[pos];
|
|
|
|
int indent = 0;
|
|
|
|
bool inPrevPrefix = line > 0;
|
2019-05-04 20:14:48 +02:00
|
|
|
Sci_Position posPrev = inPrevPrefix ? LineStart(line-1) : 0;
|
2010-08-22 01:59:56 +02:00
|
|
|
while ((ch == ' ' || ch == '\t') && (pos < end)) {
|
|
|
|
if (inPrevPrefix) {
|
2019-05-04 20:14:48 +02:00
|
|
|
const char chPrev = (*this)[posPrev++];
|
2010-08-22 01:59:56 +02:00
|
|
|
if (chPrev == ' ' || chPrev == '\t') {
|
|
|
|
if (chPrev != ch)
|
|
|
|
spaceFlags |= wsInconsistent;
|
|
|
|
} else {
|
|
|
|
inPrevPrefix = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (ch == ' ') {
|
|
|
|
spaceFlags |= wsSpace;
|
|
|
|
indent++;
|
|
|
|
} else { // Tab
|
|
|
|
spaceFlags |= wsTab;
|
|
|
|
if (spaceFlags & wsSpace)
|
|
|
|
spaceFlags |= wsSpaceTab;
|
|
|
|
indent = (indent / 8 + 1) * 8;
|
|
|
|
}
|
|
|
|
ch = (*this)[++pos];
|
|
|
|
}
|
|
|
|
|
|
|
|
*flags = spaceFlags;
|
|
|
|
indent += SC_FOLDLEVELBASE;
|
|
|
|
// if completely empty line or the start of a comment...
|
2013-08-28 02:44:27 +02:00
|
|
|
if ((LineStart(line) == Length()) || (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r') ||
|
2010-08-22 01:59:56 +02:00
|
|
|
(pfnIsCommentLeader && (*pfnIsCommentLeader)(*this, pos, end-pos)))
|
|
|
|
return indent | SC_FOLDLEVELWHITEFLAG;
|
|
|
|
else
|
|
|
|
return indent;
|
|
|
|
}
|