diff options
| author | Neil <nyamatongwe@gmail.com> | 2021-05-24 19:31:06 +1000 | 
|---|---|---|
| committer | Neil <nyamatongwe@gmail.com> | 2021-05-24 19:31:06 +1000 | 
| commit | 92290868cf9753d2df0d494cb44e2ff62a570b58 (patch) | |
| tree | 001e6cfce84372a03997de3138d630751ee8d38a /src/EditView.cxx | |
| parent | ee1886079d0a5cd350ee8e3379be347943ba93ae (diff) | |
| download | scintilla-mirror-92290868cf9753d2df0d494cb44e2ff62a570b58.tar.gz | |
Define C++ version of the Scintilla API in ScintillaTypes.h, ScintillaMessages.h
and ScintillaStructures.h using scoped enumerations.
Use these headers instead of Scintilla.h internally.
External definitions go in the Scintilla namespace and internal definitio0ns in
Scintilla::Internal.
Diffstat (limited to 'src/EditView.cxx')
| -rw-r--r-- | src/EditView.cxx | 341 | 
1 files changed, 172 insertions, 169 deletions
| diff --git a/src/EditView.cxx b/src/EditView.cxx index c71c3ce60..3ba7b8560 100644 --- a/src/EditView.cxx +++ b/src/EditView.cxx @@ -25,14 +25,16 @@  #include <memory>  #include <chrono> +#include "ScintillaTypes.h" +#include "ScintillaMessages.h" +#include "ScintillaStructures.h" +#include "ILoader.h" +#include "ILexer.h" +  #include "Debugging.h"  #include "Geometry.h"  #include "Platform.h" -#include "ILoader.h" -#include "ILexer.h" -#include "Scintilla.h" -  #include "CharacterType.h"  #include "CharacterCategoryMap.h"  #include "Position.h" @@ -61,14 +63,15 @@  #include "ElapsedPeriod.h"  using namespace Scintilla; +using namespace Scintilla::Internal;  PrintParameters::PrintParameters() noexcept {  	magnification = 0; -	colourMode = SC_PRINT_NORMAL; -	wrapState = WrapMode::word; +	colourMode = PrintOption::Normal; +	wrapState = Wrap::Word;  } -namespace Scintilla { +namespace Scintilla::Internal {  bool ValidStyledText(const ViewStyle &vs, size_t styleOffset, const StyledText &st) noexcept {  	if (st.multipleStyles) { @@ -174,12 +177,12 @@ EditView::EditView() {  	hideSelection = false;  	drawOverstrikeCaret = true;  	bufferedDraw = true; -	phasesDraw = PhasesDraw::two; +	phasesDraw = PhasesDraw::Two;  	lineWidthMaxSeen = 0;  	additionalCaretsBlink = true;  	additionalCaretsVisible = true;  	imeCaretBlockOverride = false; -	llc.SetLevel(LineLayoutCache::Cache::caret); +	llc.SetLevel(LineCache::Caret);  	posCache.SetSize(0x400);  	tabArrowHeight = 4;  	customDrawTabArrow = nullptr; @@ -189,7 +192,7 @@ EditView::EditView() {  EditView::~EditView() = default;  bool EditView::SetTwoPhaseDraw(bool twoPhaseDraw) noexcept { -	const PhasesDraw phasesDrawNew = twoPhaseDraw ? PhasesDraw::two : PhasesDraw::one; +	const PhasesDraw phasesDrawNew = twoPhaseDraw ? PhasesDraw::Two : PhasesDraw::One;  	const bool redraw = phasesDraw != phasesDrawNew;  	phasesDraw = phasesDrawNew;  	return redraw; @@ -203,7 +206,7 @@ bool EditView::SetPhasesDraw(int phases) noexcept {  }  bool EditView::LinesOverlap() const noexcept { -	return phasesDraw == PhasesDraw::multiple; +	return phasesDraw == PhasesDraw::Multiple;  }  void EditView::ClearAllTabstops() noexcept { @@ -285,7 +288,7 @@ static void DrawTabArrow(Surface *surface, PRectangle rcTab, int ymid,  	}  	// Draw the arrow head if needed -	if (vsDraw.tabDrawMode == TabDrawMode::longArrow) { +	if (vsDraw.tabDrawMode == TabDrawMode::LongArrow) {  		XYPOSITION ydiff = std::floor(rcTab.Height() / 2.0f);  		XYPOSITION xhead = rightStroke - ydiff;  		if (xhead <= rcTab.left) { @@ -307,12 +310,12 @@ void EditView::RefreshPixMaps(Surface *surfaceWindow, const ViewStyle &vsDraw) {  		pixmapIndentGuide = surfaceWindow->AllocatePixMap(1, vsDraw.lineHeight + 1);  		pixmapIndentGuideHighlight = surfaceWindow->AllocatePixMap(1, vsDraw.lineHeight + 1);  		const PRectangle rcIG = PRectangle::FromInts(0, 0, 1, vsDraw.lineHeight); -		pixmapIndentGuide->FillRectangle(rcIG, vsDraw.styles[STYLE_INDENTGUIDE].back); -		pixmapIndentGuideHighlight->FillRectangle(rcIG, vsDraw.styles[STYLE_BRACELIGHT].back); +		pixmapIndentGuide->FillRectangle(rcIG, vsDraw.styles[StyleIndentGuide].back); +		pixmapIndentGuideHighlight->FillRectangle(rcIG, vsDraw.styles[StyleBraceLight].back);  		for (int stripe = 1; stripe < vsDraw.lineHeight + 1; stripe += 2) {  			const PRectangle rcPixel = PRectangle::FromInts(0, stripe, 1, stripe + 1); -			pixmapIndentGuide->FillRectangle(rcPixel, vsDraw.styles[STYLE_INDENTGUIDE].fore); -			pixmapIndentGuideHighlight->FillRectangle(rcPixel, vsDraw.styles[STYLE_BRACELIGHT].fore); +			pixmapIndentGuide->FillRectangle(rcPixel, vsDraw.styles[StyleIndentGuide].fore); +			pixmapIndentGuideHighlight->FillRectangle(rcPixel, vsDraw.styles[StyleBraceLight].fore);  		}  		pixmapIndentGuide->FlushDrawing();  		pixmapIndentGuideHighlight->FlushDrawing(); @@ -420,7 +423,7 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt  	if (ll->validity == LineLayout::ValidLevel::invalid) {  		ll->widthLine = LineLayout::wrapWidthInfinite;  		ll->lines = 1; -		if (vstyle.edgeState == EDGE_BACKGROUND) { +		if (vstyle.edgeState == EdgeVisualStyle::Background) {  			Sci::Position edgePosition = model.pdoc->FindColumn(line, vstyle.theEdge.column);  			if (edgePosition >= posLineStart) {  				edgePosition -= posLineStart; @@ -471,7 +474,7 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt  					} else {  						if (representationWidth <= 0.0) {  							XYPOSITION positionsRepr[256];	// Should expand when needed -							posCache.MeasureWidths(surface, vstyle, STYLE_CONTROLCHAR, ts.representation->stringRep.c_str(), +							posCache.MeasureWidths(surface, vstyle, StyleControlChar, ts.representation->stringRep.c_str(),  								static_cast<unsigned int>(ts.representation->stringRep.length()), positionsRepr, model.pdoc);  							representationWidth = positionsRepr[ts.representation->stringRep.length() - 1] + vstyle.ctrlCharPadding;  						} @@ -511,25 +514,25 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt  			// Simple common case where line does not need wrapping.  			ll->lines = 1;  		} else { -			if (vstyle.wrap.visualFlags & SC_WRAPVISUALFLAG_END) { +			if (FlagSet(vstyle.wrap.visualFlags, WrapVisualFlag::End)) {  				width -= static_cast<int>(vstyle.aveCharWidth); // take into account the space for end wrap mark  			}  			XYPOSITION wrapAddIndent = 0; // This will be added to initial indent of line  			switch (vstyle.wrap.indentMode) { -			case SC_WRAPINDENT_FIXED: +			case WrapIndentMode::Fixed:  				wrapAddIndent = vstyle.wrap.visualStartIndent * vstyle.aveCharWidth;  				break; -			case SC_WRAPINDENT_INDENT: +			case WrapIndentMode::Indent:  				wrapAddIndent = model.pdoc->IndentSize() * vstyle.spaceWidth;  				break; -			case SC_WRAPINDENT_DEEPINDENT: +			case WrapIndentMode::DeepIndent:  				wrapAddIndent = model.pdoc->IndentSize() * 2 * vstyle.spaceWidth;  				break; -			default:	// No additional indent for SC_WRAPINDENT_FIXED +			default:	// No additional indent for WrapIndentMode::Fixed  				break;  			}  			ll->wrapIndent = wrapAddIndent; -			if (vstyle.wrap.indentMode != SC_WRAPINDENT_FIXED) { +			if (vstyle.wrap.indentMode != WrapIndentMode::Fixed) {  				for (int i = 0; i < ll->numCharsInLine; i++) {  					if (!IsSpaceOrTab(ll->chars[i])) {  						ll->wrapIndent += ll->positions[i]; // Add line indent @@ -541,7 +544,7 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt  			if (ll->wrapIndent > width - static_cast<int>(vstyle.aveCharWidth) * 15)  				ll->wrapIndent = wrapAddIndent;  			// Check for wrapIndent minimum -			if ((vstyle.wrap.visualFlags & SC_WRAPVISUALFLAG_START) && (ll->wrapIndent < vstyle.aveCharWidth)) +			if ((FlagSet(vstyle.wrap.visualFlags, WrapVisualFlag::Start)) && (ll->wrapIndent < vstyle.aveCharWidth))  				ll->wrapIndent = vstyle.aveCharWidth; // Indent to show start visual  			ll->lines = 0;  			// Calculate line start positions based upon width. @@ -573,12 +576,12 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt  					continue;  				}  				if (p > 0) { -					if (vstyle.wrap.state == WrapMode::character) { +					if (vstyle.wrap.state == Wrap::Char) {  						lastGoodBreak = model.pdoc->MovePositionOutsideChar(p + posLineStart, -1)  							- posLineStart;  						p = model.pdoc->MovePositionOutsideChar(p + 1 + posLineStart, 1) - posLineStart;  						continue; -					} else if ((vstyle.wrap.state == WrapMode::word) && (ll->styles[p] != ll->styles[p - 1])) { +					} else if ((vstyle.wrap.state == Wrap::Word) && (ll->styles[p] != ll->styles[p - 1])) {  						lastGoodBreak = p;  					} else if (IsSpaceOrTab(ll->chars[p - 1]) && !IsSpaceOrTab(ll->chars[p])) {  						lastGoodBreak = p; @@ -832,27 +835,27 @@ ColourRGBA SelectionBackground(const EditModel &model, const ViewStyle &vsDraw,  	if (inSelection == InSelection::inNone)  		return bugColour;	// Not selected is a bug -	int element = SC_ELEMENT_SELECTION_BACK; +	Element element = Element::SelectionBack;  	if (inSelection == InSelection::inAdditional) -		element = SC_ELEMENT_SELECTION_ADDITIONAL_BACK; +		element = Element::SelectionAdditionalBack;  	if (!model.primarySelection) -		element = SC_ELEMENT_SELECTION_SECONDARY_BACK; -	if (!model.hasFocus && vsDraw.ElementColour(SC_ELEMENT_SELECTION_NO_FOCUS_BACK)) -		element = SC_ELEMENT_SELECTION_NO_FOCUS_BACK; +		element = Element::SelectionSecondaryBack; +	if (!model.hasFocus && vsDraw.ElementColour(Element::SelectionNoFocusBack)) +		element = Element::SelectionNoFocusBack;  	return vsDraw.ElementColour(element).value_or(bugColour);  }  std::optional<ColourRGBA> SelectionForeground(const EditModel &model, const ViewStyle &vsDraw, InSelection inSelection) {  	if (inSelection == InSelection::inNone)  		return {}; -	int element = SC_ELEMENT_SELECTION_TEXT; +	Element element = Element::SelectionText;  	if (inSelection == InSelection::inAdditional) -		element = SC_ELEMENT_SELECTION_ADDITIONAL_TEXT; +		element = Element::SelectionAdditionalText;  	if (!model.primarySelection)	// Secondary selection -		element = SC_ELEMENT_SELECTION_SECONDARY_TEXT; +		element = Element::SelectionSecondaryText;  	if (!model.hasFocus) { -		if (vsDraw.ElementColour(SC_ELEMENT_SELECTION_NO_FOCUS_TEXT)) { -			element = SC_ELEMENT_SELECTION_NO_FOCUS_TEXT; +		if (vsDraw.ElementColour(Element::SelectionNoFocusText)) { +			element = Element::SelectionNoFocusText;  		} else {  			return {};  		} @@ -864,16 +867,16 @@ std::optional<ColourRGBA> SelectionForeground(const EditModel &model, const View  static ColourRGBA TextBackground(const EditModel &model, const ViewStyle &vsDraw, const LineLayout *ll,  	std::optional<ColourRGBA> background, InSelection inSelection, bool inHotspot, int styleMain, Sci::Position i) { -	if (inSelection && (vsDraw.selection.layer == Layer::base)) { +	if (inSelection && (vsDraw.selection.layer == Layer::Base)) {  		return SelectionBackground(model, vsDraw, inSelection).Opaque();  	} -	if ((vsDraw.edgeState == EDGE_BACKGROUND) && +	if ((vsDraw.edgeState == EdgeVisualStyle::Background) &&  		(i >= ll->edgeColumn) &&  		(i < ll->numCharsBeforeEOL))  		return vsDraw.theEdge.colour; -	if (inHotspot && vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE_BACK)) -		return vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE_BACK)->Opaque(); -	if (background && (styleMain != STYLE_BRACELIGHT) && (styleMain != STYLE_BRACEBAD)) { +	if (inHotspot && vsDraw.ElementColour(Element::HotSpotActiveBack)) +		return vsDraw.ElementColour(Element::HotSpotActiveBack)->Opaque(); +	if (background && (styleMain != StyleBraceLight) && (styleMain != StyleBraceBad)) {  		return *background;  	} else {  		return vsDraw.styles[styleMain].back; @@ -895,8 +898,8 @@ static void DrawTextBlob(Surface *surface, const ViewStyle &vsDraw, PRectangle r  	if (fillBackground) {  		surface->FillRectangleAligned(rcSegment, Fill(textBack));  	} -	const Font *ctrlCharsFont = vsDraw.styles[STYLE_CONTROLCHAR].font.get(); -	const int normalCharHeight = static_cast<int>(std::ceil(vsDraw.styles[STYLE_CONTROLCHAR].capitalHeight)); +	const Font *ctrlCharsFont = vsDraw.styles[StyleControlChar].font.get(); +	const int normalCharHeight = static_cast<int>(std::ceil(vsDraw.styles[StyleControlChar].capitalHeight));  	PRectangle rcCChar = rcSegment;  	rcCChar.left = rcCChar.left + 1;  	rcCChar.top = rcSegment.top + vsDraw.maxAscent - normalCharHeight; @@ -914,12 +917,12 @@ static void DrawTextBlob(Surface *surface, const ViewStyle &vsDraw, PRectangle r  }  static void DrawCaretLineFramed(Surface *surface, const ViewStyle &vsDraw, const LineLayout *ll, PRectangle rcLine, int subLine) { -	const std::optional<ColourRGBA> caretlineBack = vsDraw.ElementColour(SC_ELEMENT_CARET_LINE_BACK); +	const std::optional<ColourRGBA> caretlineBack = vsDraw.ElementColour(Element::CaretLineBack);  	if (!caretlineBack) {  		return;  	} -	const ColourRGBA colourFrame = (vsDraw.caretLine.layer == Layer::base) ? +	const ColourRGBA colourFrame = (vsDraw.caretLine.layer == Layer::Base) ?  		caretlineBack->Opaque() : *caretlineBack;  	const int width = vsDraw.GetFrameWidth(); @@ -927,7 +930,7 @@ static void DrawCaretLineFramed(Surface *surface, const ViewStyle &vsDraw, const  	// Avoid double drawing the corners by removing the left and right sides when drawing top and bottom borders  	const PRectangle rcWithoutLeftRight = rcLine.Inset(Point(width, 0.0)); -	if (subLine == 0 || ll->wrapIndent == 0 || vsDraw.caretLine.layer != Layer::base) { +	if (subLine == 0 || ll->wrapIndent == 0 || vsDraw.caretLine.layer != Layer::Base) {  		// Left  		surface->FillRectangleAligned(Side(rcLine, Edge::left, width), colourFrame);  	} @@ -935,7 +938,7 @@ static void DrawCaretLineFramed(Surface *surface, const ViewStyle &vsDraw, const  		// Top  		surface->FillRectangleAligned(Side(rcWithoutLeftRight, Edge::top, width), colourFrame);  	} -	if (subLine == ll->lines - 1 || vsDraw.caretLine.layer != Layer::base) { +	if (subLine == ll->lines - 1 || vsDraw.caretLine.layer != Layer::Base) {  		// Right  		surface->FillRectangleAligned(Side(rcLine, Edge::right, width), colourFrame);  	} @@ -966,7 +969,7 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  		rcSegment.right = xEol + xStart + virtualSpace;  		const ColourRGBA backgroundFill = background.value_or(vsDraw.styles[ll->styles[ll->numCharsInLine]].back);  		surface->FillRectangleAligned(rcSegment, backgroundFill); -		if (!hideSelection && (vsDraw.selection.layer == Layer::base)) { +		if (!hideSelection && (vsDraw.selection.layer == Layer::Base)) {  			const SelectionSegment virtualSpaceRange(SelectionPosition(model.pdoc->LineEnd(line)),  				SelectionPosition(model.pdoc->LineEnd(line),  					model.sel.VirtualSpaceFor(model.pdoc->LineEnd(line)))); @@ -1021,7 +1024,7 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  			const std::optional<ColourRGBA> selectionFore = SelectionForeground(model, vsDraw, eolInSelection);  			const ColourRGBA textFore = selectionFore.value_or(vsDraw.styles[styleMain].fore);  			if (eolInSelection && (line < model.pdoc->LinesTotal() - 1)) { -				if (vsDraw.selection.layer == Layer::base) { +				if (vsDraw.selection.layer == Layer::Base) {  					surface->FillRectangleAligned(rcSegment, Fill(selectionBack.Opaque()));  				} else {  					surface->FillRectangleAligned(rcSegment, Fill(textBack)); @@ -1031,12 +1034,12 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  			}  			const bool drawEOLSelection = eolInSelection && (line < model.pdoc->LinesTotal() - 1);  			ColourRGBA blobText = textBack; -			if (drawEOLSelection && (vsDraw.selection.layer == Layer::under)) { +			if (drawEOLSelection && (vsDraw.selection.layer == Layer::UnderText)) {  				surface->FillRectangleAligned(rcSegment, selectionBack);  				blobText = textBack.MixedWith(selectionBack, selectionBack.GetAlphaComponent());  			} -			DrawTextBlob(surface, vsDraw, rcSegment, ctrlChar, blobText, textFore, phasesDraw == PhasesDraw::one); -			if (drawEOLSelection && (vsDraw.selection.layer == Layer::over)) { +			DrawTextBlob(surface, vsDraw, rcSegment, ctrlChar, blobText, textFore, phasesDraw == PhasesDraw::One); +			if (drawEOLSelection && (vsDraw.selection.layer == Layer::OverText)) {  				surface->FillRectangleAligned(rcSegment, selectionBack);  			}  		} @@ -1046,7 +1049,7 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  	rcSegment.left = xEol + xStart + virtualSpace + blobsWidth;  	rcSegment.right = rcSegment.left + vsDraw.aveCharWidth; -	if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer == Layer::base)) { +	if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer == Layer::Base)) {  		surface->FillRectangleAligned(rcSegment, Fill(selectionBack.Opaque()));  	} else {  		if (background) { @@ -1056,9 +1059,9 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  		} else if (vsDraw.styles[ll->styles[ll->numCharsInLine]].eolFilled) {  			surface->FillRectangleAligned(rcSegment, Fill(vsDraw.styles[ll->styles[ll->numCharsInLine]].back));  		} else { -			surface->FillRectangleAligned(rcSegment, Fill(vsDraw.styles[STYLE_DEFAULT].back)); +			surface->FillRectangleAligned(rcSegment, Fill(vsDraw.styles[StyleDefault].back));  		} -		if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::base)) { +		if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::Base)) {  			surface->FillRectangleAligned(rcSegment, selectionBack);  		}  	} @@ -1068,7 +1071,7 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  		rcSegment.left = rcLine.left;  	rcSegment.right = rcLine.right; -	const bool drawEOLAnnotationStyledText = (vsDraw.eolAnnotationVisible != EOLANNOTATION_HIDDEN) && model.pdoc->EOLAnnotationStyledText(line).text; +	const bool drawEOLAnnotationStyledText = (vsDraw.eolAnnotationVisible != EOLAnnotationVisible::Hidden) && model.pdoc->EOLAnnotationStyledText(line).text;  	const bool fillRemainder = (!lastSubLine || (!model.GetFoldDisplayText(line) && !drawEOLAnnotationStyledText));  	if (fillRemainder) {  		// Fill the remainder of the line @@ -1078,20 +1081,20 @@ void EditView::DrawEOL(Surface *surface, const EditModel &model, const ViewStyle  	bool drawWrapMarkEnd = false;  	if (subLine + 1 < ll->lines) { -		if (vsDraw.wrap.visualFlags & SC_WRAPVISUALFLAG_END) { +		if (FlagSet(vsDraw.wrap.visualFlags, WrapVisualFlag::End)) {  			drawWrapMarkEnd = ll->LineStart(subLine + 1) != 0;  		}  		if (vsDraw.IsLineFrameOpaque(model.caret.active, ll->containsCaret)) {  			// Draw right of frame under marker  			surface->FillRectangleAligned(Side(rcLine, Edge::right, vsDraw.GetFrameWidth()), -				vsDraw.ElementColour(SC_ELEMENT_CARET_LINE_BACK)->Opaque()); +				vsDraw.ElementColour(Element::CaretLineBack)->Opaque());  		}  	}  	if (drawWrapMarkEnd) {  		PRectangle rcPlace = rcSegment; -		if (vsDraw.wrap.visualFlagsLocation & SC_WRAPVISUALFLAGLOC_END_BY_TEXT) { +		if (FlagSet(vsDraw.wrap.visualFlagsLocation, WrapVisualLocation::EndByText)) {  			rcPlace.left = xEol + xStart + virtualSpace;  			rcPlace.right = rcPlace.left + vsDraw.aveCharWidth;  		} else { @@ -1185,9 +1188,9 @@ static void DrawIndicators(Surface *surface, const EditModel &model, const ViewS  	}  	// Use indicators to highlight matching braces -	if ((vsDraw.braceHighlightIndicatorSet && (model.bracesMatchStyle == STYLE_BRACELIGHT)) || -		(vsDraw.braceBadLightIndicatorSet && (model.bracesMatchStyle == STYLE_BRACEBAD))) { -		const int braceIndicator = (model.bracesMatchStyle == STYLE_BRACELIGHT) ? vsDraw.braceHighlightIndicator : vsDraw.braceBadLightIndicator; +	if ((vsDraw.braceHighlightIndicatorSet && (model.bracesMatchStyle == StyleBraceLight)) || +		(vsDraw.braceBadLightIndicatorSet && (model.bracesMatchStyle == StyleBraceBad))) { +		const int braceIndicator = (model.bracesMatchStyle == StyleBraceLight) ? vsDraw.braceHighlightIndicator : vsDraw.braceBadLightIndicator;  		if (under == vsDraw.indicators[braceIndicator].under) {  			const Range rangeLine(posLineStart + lineStart, posLineEnd);  			if (rangeLine.ContainsCharacter(model.braces[0])) { @@ -1222,7 +1225,7 @@ void EditView::DrawFoldDisplayText(Surface *surface, const EditModel &model, con  	PRectangle rcSegment = rcLine;  	const std::string_view foldDisplayText(text); -	const Font *fontText = vsDraw.styles[STYLE_FOLDDISPLAYTEXT].font.get(); +	const Font *fontText = vsDraw.styles[StyleFoldDisplayText].font.get();  	const int widthFoldDisplayText = static_cast<int>(surface->WidthText(fontText, foldDisplayText));  	InSelection eolInSelection = InSelection::inNone; @@ -1238,9 +1241,9 @@ void EditView::DrawFoldDisplayText(Surface *surface, const EditModel &model, con  	const std::optional<ColourRGBA> background = vsDraw.Background(model.pdoc->GetMark(line), model.caret.active, ll->containsCaret);  	const std::optional<ColourRGBA> selectionFore = SelectionForeground(model, vsDraw, eolInSelection); -	const ColourRGBA textFore = selectionFore.value_or(vsDraw.styles[STYLE_FOLDDISPLAYTEXT].fore); +	const ColourRGBA textFore = selectionFore.value_or(vsDraw.styles[StyleFoldDisplayText].fore);  	const ColourRGBA textBack = TextBackground(model, vsDraw, ll, background, eolInSelection, -											false, STYLE_FOLDDISPLAYTEXT, -1); +											false, StyleFoldDisplayText, -1);  	if (model.trackLineWidth) {  		if (rcSegment.right + 1> lineWidthMaxSeen) { @@ -1262,7 +1265,7 @@ void EditView::DrawFoldDisplayText(Surface *surface, const EditModel &model, con  	}  	if (FlagSet(phase, DrawPhase::text)) { -		if (phasesDraw != PhasesDraw::one) { +		if (phasesDraw != PhasesDraw::One) {  			surface->DrawTextTransparent(rcSegment, fontText,  				rcSegment.top + vsDraw.maxAscent, foldDisplayText,  				textFore); @@ -1274,7 +1277,7 @@ void EditView::DrawFoldDisplayText(Surface *surface, const EditModel &model, con  	}  	if (FlagSet(phase, DrawPhase::indicatorsFore)) { -		if (model.foldDisplayTextStyle == SC_FOLDDISPLAYTEXT_BOXED) { +		if (model.foldDisplayTextStyle == FoldDisplayTextStyle::Boxed) {  			PRectangle rcBox = rcSegment;  			rcBox.left = std::round(rcSegment.left);  			rcBox.right = std::round(rcSegment.right); @@ -1283,7 +1286,7 @@ void EditView::DrawFoldDisplayText(Surface *surface, const EditModel &model, con  	}  	if (FlagSet(phase, DrawPhase::selectionTranslucent)) { -		if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::base)) { +		if (eolInSelection && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::Base)) {  			surface->FillRectangleAligned(rcSegment, SelectionBackground(model, vsDraw, eolInSelection));  		}  	} @@ -1295,7 +1298,7 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	if (!lastSubLine)  		return; -	if (vsDraw.eolAnnotationVisible == EOLANNOTATION_HIDDEN) { +	if (vsDraw.eolAnnotationVisible == EOLAnnotationVisible::Hidden) {  		return;  	}  	const StyledText stEOLAnnotation = model.pdoc->EOLAnnotationStyledText(line); @@ -1308,16 +1311,16 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	PRectangle rcSegment = rcLine;  	const Font *fontText = vsDraw.styles[style].font.get(); -	const Surface::Ends ends = static_cast<Surface::Ends>(vsDraw.eolAnnotationVisible & 0xff); +	const Surface::Ends ends = static_cast<Surface::Ends>(static_cast<int>(vsDraw.eolAnnotationVisible) & 0xff);  	const Surface::Ends leftSide = static_cast<Surface::Ends>(static_cast<int>(ends) & 0xf);  	const Surface::Ends rightSide = static_cast<Surface::Ends>(static_cast<int>(ends) & 0xf0);  	XYPOSITION leftBoxSpace = 0;  	XYPOSITION rightBoxSpace = 0; -	if (vsDraw.eolAnnotationVisible >= EOLANNOTATION_BOXED) { +	if (vsDraw.eolAnnotationVisible >= EOLAnnotationVisible::Boxed) {  		leftBoxSpace = 1;  		rightBoxSpace = 1; -		if (vsDraw.eolAnnotationVisible != EOLANNOTATION_BOXED) { +		if (vsDraw.eolAnnotationVisible != EOLAnnotationVisible::Boxed) {  			switch (leftSide) {  			case Surface::Ends::leftFlat:  				leftBoxSpace = 1; @@ -1389,7 +1392,7 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	// For single phase drawing, draw the text then any box over it  	if (FlagSet(phase, DrawPhase::text)) { -		if (phasesDraw == PhasesDraw::one) { +		if (phasesDraw == PhasesDraw::One) {  			surface->DrawTextNoClipUTF8(rcText, fontText,  			rcText.top + vsDraw.maxAscent, eolAnnotationText,  			textFore, textBack); @@ -1398,14 +1401,14 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	// Draw any box or stadium shape  	if (FlagSet(phase, DrawPhase::indicatorsBack)) { -		if (vsDraw.eolAnnotationVisible >= EOLANNOTATION_BOXED) { +		if (vsDraw.eolAnnotationVisible >= EOLAnnotationVisible::Boxed) {  			PRectangle rcBox = rcSegment;  			rcBox.left = std::round(rcSegment.left);  			rcBox.right = std::round(rcSegment.right); -			if (vsDraw.eolAnnotationVisible == EOLANNOTATION_BOXED) { +			if (vsDraw.eolAnnotationVisible == EOLAnnotationVisible::Boxed) {  				surface->RectangleFrame(rcBox, Stroke(textFore));  			} else { -				if (phasesDraw == PhasesDraw::one) { +				if (phasesDraw == PhasesDraw::One) {  					// Draw an outline around the text  					surface->Stadium(rcBox, FillStroke(ColourRGBA(textBack, 0), textFore, 1.0), ends);  				} else { @@ -1418,7 +1421,7 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	// For multi-phase drawing draw the text last as transparent over any box   	if (FlagSet(phase, DrawPhase::text)) { -		if (phasesDraw != PhasesDraw::one) { +		if (phasesDraw != PhasesDraw::One) {  			surface->DrawTextTransparentUTF8(rcText, fontText,  				rcText.top + vsDraw.maxAscent, eolAnnotationText,  				textFore); @@ -1426,8 +1429,8 @@ void EditView::DrawEOLAnnotationText(Surface *surface, const EditModel &model, c  	}  } -static constexpr bool AnnotationBoxedOrIndented(int annotationVisible) noexcept { -	return annotationVisible == ANNOTATION_BOXED || annotationVisible == ANNOTATION_INDENTED; +static constexpr bool AnnotationBoxedOrIndented(AnnotationVisible annotationVisible) noexcept { +	return annotationVisible == AnnotationVisible::Boxed || annotationVisible == AnnotationVisible::Indented;  }  void EditView::DrawAnnotation(Surface *surface, const EditModel &model, const ViewStyle &vsDraw, const LineLayout *ll, @@ -1469,7 +1472,7 @@ void EditView::DrawAnnotation(Surface *surface, const EditModel &model, const Vi  		}  		DrawStyledText(surface, vsDraw, vsDraw.annotationStyleOffset, rcText,  			stAnnotation, start, lengthAnnotation, phase); -		if ((FlagSet(phase, DrawPhase::back)) && (vsDraw.annotationVisible == ANNOTATION_BOXED)) { +		if ((FlagSet(phase, DrawPhase::back)) && (vsDraw.annotationVisible == AnnotationVisible::Boxed)) {  			const ColourRGBA colourBorder = vsDraw.styles[vsDraw.annotationStyleOffset].fore;  			const PRectangle rcBorder = PixelAlignOutside(rcSegment, surface->PixelDivisions());  			surface->FillRectangle(Side(rcBorder, Edge::left, 1), colourBorder); @@ -1641,7 +1644,7 @@ void EditView::DrawCarets(Surface *surface, const EditModel &model, const ViewSt  					rcCaret.left = std::round(xposCaret - caretWidthOffset);  					rcCaret.right = rcCaret.left + vsDraw.caret.width;  				} -				const int elementCaret = mainCaret ? SC_ELEMENT_CARET : SC_ELEMENT_CARET_ADDITIONAL; +				const Element elementCaret = mainCaret ? Element::Caret : Element::CaretAdditional;  				const ColourRGBA caretColour = *vsDraw.ElementColour(elementCaret);  				//assert(caretColour.IsOpaque());  				if (drawBlockCaret) { @@ -1661,15 +1664,15 @@ static void DrawWrapIndentAndMarker(Surface *surface, const ViewStyle &vsDraw, c  	bool caretActive) {  	// default bgnd here..  	surface->FillRectangleAligned(rcLine, Fill(background ? *background : -		vsDraw.styles[STYLE_DEFAULT].back)); +		vsDraw.styles[StyleDefault].back));  	if (vsDraw.IsLineFrameOpaque(caretActive, ll->containsCaret)) {  		// Draw left of frame under marker  		surface->FillRectangleAligned(Side(rcLine, Edge::left, vsDraw.GetFrameWidth()), -			vsDraw.ElementColour(SC_ELEMENT_CARET_LINE_BACK)->Opaque()); +			vsDraw.ElementColour(Element::CaretLineBack)->Opaque());  	} -	if (vsDraw.wrap.visualFlags & SC_WRAPVISUALFLAG_START) { +	if (FlagSet(vsDraw.wrap.visualFlags, WrapVisualFlag::Start)) {  		// draw continuation rect  		PRectangle rcPlace = rcLine; @@ -1677,7 +1680,7 @@ static void DrawWrapIndentAndMarker(Surface *surface, const ViewStyle &vsDraw, c  		rcPlace.left = static_cast<XYPOSITION>(xStart);  		rcPlace.right = rcPlace.left + ll->wrapIndent; -		if (vsDraw.wrap.visualFlagsLocation & SC_WRAPVISUALFLAGLOC_START_BY_TEXT) +		if (FlagSet(vsDraw.wrap.visualFlagsLocation, WrapVisualLocation::StartByText))  			rcPlace.left = rcPlace.right - vsDraw.aveCharWidth;  		else  			rcPlace.right = rcPlace.left + vsDraw.aveCharWidth; @@ -1731,7 +1734,7 @@ void EditView::DrawBackground(Surface *surface, const EditModel &model, const Vi  				if (ll->chars[i] == '\t') {  					// Tab display  					if (drawWhitespaceBackground && vsDraw.WhiteSpaceVisible(inIndentation)) { -						textBack = vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE_BACK)->Opaque(); +						textBack = vsDraw.ElementColour(Element::WhiteSpaceBack)->Opaque();  					}  				} else {  					// Blob display @@ -1741,7 +1744,7 @@ void EditView::DrawBackground(Surface *surface, const EditModel &model, const Vi  			} else {  				// Normal text display  				surface->FillRectangleAligned(rcSegment, Fill(textBack)); -				if (vsDraw.viewWhitespace != WhiteSpace::invisible) { +				if (vsDraw.viewWhitespace != WhiteSpace::Invisible) {  					for (int cpos = 0; cpos <= i - ts.start; cpos++) {  						if (ll->chars[cpos + ts.start] == ' ') {  							if (drawWhitespaceBackground && vsDraw.WhiteSpaceVisible(inIndentation)) { @@ -1751,7 +1754,7 @@ void EditView::DrawBackground(Surface *surface, const EditModel &model, const Vi  									ll->positions[cpos + ts.start + 1] + xStart - static_cast<XYPOSITION>(subLineStart),  									rcSegment.bottom);  								surface->FillRectangleAligned(rcSpace, -									vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE_BACK)->Opaque()); +									vsDraw.ElementColour(Element::WhiteSpaceBack)->Opaque());  							}  						} else {  							inIndentation = false; @@ -1767,7 +1770,7 @@ void EditView::DrawBackground(Surface *surface, const EditModel &model, const Vi  static void DrawEdgeLine(Surface *surface, const ViewStyle &vsDraw, const LineLayout *ll, PRectangle rcLine,  	Range lineRange, int xStart) { -	if (vsDraw.edgeState == EDGE_LINE) { +	if (vsDraw.edgeState == EdgeVisualStyle::Line) {  		PRectangle rcSegment = rcLine;  		const int edgeX = static_cast<int>(vsDraw.theEdge.column * vsDraw.spaceWidth);  		rcSegment.left = static_cast<XYPOSITION>(edgeX + xStart); @@ -1775,7 +1778,7 @@ static void DrawEdgeLine(Surface *surface, const ViewStyle &vsDraw, const LineLa  			rcSegment.left -= ll->wrapIndent;  		rcSegment.right = rcSegment.left + 1;  		surface->FillRectangleAligned(rcSegment, Fill(vsDraw.theEdge.colour)); -	} else if (vsDraw.edgeState == EDGE_MULTILINE) { +	} else if (vsDraw.edgeState == EdgeVisualStyle::MultiLine) {  		for (size_t edge = 0; edge < vsDraw.theMultiEdge.size(); edge++) {  			if (vsDraw.theMultiEdge[edge].column >= 0) {  				PRectangle rcSegment = rcLine; @@ -1795,8 +1798,8 @@ static void DrawMarkUnderline(Surface *surface, const EditModel &model, const Vi  	Sci::Line line, PRectangle rcLine) {  	int marks = model.pdoc->GetMark(line);  	for (int markBit = 0; (markBit < 32) && marks; markBit++) { -		if ((marks & 1) && (vsDraw.markers[markBit].markType == SC_MARK_UNDERLINE) && -			(vsDraw.markers[markBit].layer == Layer::base)) { +		if ((marks & 1) && (vsDraw.markers[markBit].markType == MarkerSymbol::Underline) && +			(vsDraw.markers[markBit].layer == Layer::Base)) {  			PRectangle rcUnderline = rcLine;  			rcUnderline.top = rcUnderline.bottom - 2;  			surface->FillRectangleAligned(rcUnderline, Fill(vsDraw.markers[markBit].back)); @@ -1870,21 +1873,21 @@ static void DrawTranslucentSelection(Surface *surface, const EditModel &model, c  // Draw any translucent whole line states  static void DrawTranslucentLineState(Surface *surface, const EditModel &model, const ViewStyle &vsDraw, const LineLayout *ll,  	Sci::Line line, PRectangle rcLine, int subLine, Layer layer) { -	if ((model.caret.active || vsDraw.caretLine.alwaysShow) && vsDraw.ElementColour(SC_ELEMENT_CARET_LINE_BACK) && ll->containsCaret && +	if ((model.caret.active || vsDraw.caretLine.alwaysShow) && vsDraw.ElementColour(Element::CaretLineBack) && ll->containsCaret &&  		vsDraw.caretLine.layer == layer) {  		if (vsDraw.caretLine.frame) {  			DrawCaretLineFramed(surface, vsDraw, ll, rcLine, subLine);  		} else { -			surface->FillRectangleAligned(rcLine, *vsDraw.ElementColour(SC_ELEMENT_CARET_LINE_BACK)); +			surface->FillRectangleAligned(rcLine, *vsDraw.ElementColour(Element::CaretLineBack));  		}  	}  	const int marksOfLine = model.pdoc->GetMark(line);  	int marksDrawnInText = marksOfLine & vsDraw.maskDrawInText;  	for (int markBit = 0; (markBit < 32) && marksDrawnInText; markBit++) {  		if ((marksDrawnInText & 1) && (vsDraw.markers[markBit].layer == layer)) { -			if (vsDraw.markers[markBit].markType == SC_MARK_BACKGROUND) { +			if (vsDraw.markers[markBit].markType == MarkerSymbol::Background) {  				surface->FillRectangleAligned(rcLine, vsDraw.markers[markBit].BackWithAlpha()); -			} else if (vsDraw.markers[markBit].markType == SC_MARK_UNDERLINE) { +			} else if (vsDraw.markers[markBit].markType == MarkerSymbol::Underline) {  				PRectangle rcUnderline = rcLine;  				rcUnderline.top = rcUnderline.bottom - 2;  				surface->FillRectangleAligned(rcUnderline, vsDraw.markers[markBit].BackWithAlpha()); @@ -1917,7 +1920,7 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  	// Foreground drawing loop  	BreakFinder bfFore(ll, &model.sel, lineRange, posLineStart, xStartVisible, -		(((phasesDraw == PhasesDraw::one) && selBackDrawn) || vsDraw.SelectionTextDrawn()), model.pdoc, &model.reprs, &vsDraw); +		(((phasesDraw == PhasesDraw::One) && selBackDrawn) || vsDraw.SelectionTextDrawn()), model.pdoc, &model.reprs, &vsDraw);  	while (bfFore.More()) { @@ -1937,8 +1940,8 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  			// Hot-spot foreground  			const bool inHotspot = (ll->hotspot.Valid()) && ll->hotspot.ContainsCharacter(iDoc);  			if (inHotspot) { -				if (vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE)) -					textFore = *vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE); +				if (vsDraw.ElementColour(Element::HotSpotActive)) +					textFore = *vsDraw.ElementColour(Element::HotSpotActive);  			}  			if (vsDraw.indicatorsSetFore) {  				// At least one indicator sets the text colour so see if it applies to this segment @@ -1953,13 +1956,13 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  							hover =	rangeRun.ContainsCharacter(model.hoverIndicatorPos);  						}  						if (hover) { -							if (indicator.sacHover.style == INDIC_TEXTFORE) { +							if (indicator.sacHover.style == IndicatorStyle::TextFore) {  								textFore = indicator.sacHover.fore;  							}  						} else { -							if (indicator.sacNormal.style == INDIC_TEXTFORE) { -								if (indicator.Flags() & SC_INDICFLAG_VALUEFORE) -									textFore = ColourRGBA::FromRGB(indicatorValue & SC_INDICVALUEMASK); +							if (indicator.sacNormal.style == IndicatorStyle::TextFore) { +								if (FlagSet(indicator.Flags(), IndicFlag::ValueFore)) +									textFore = ColourRGBA::FromRGB(indicatorValue & static_cast<int>(IndicValue::Mask));  								else  									textFore = indicator.sacNormal.fore;  							} @@ -1976,12 +1979,12 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  			if (ts.representation) {  				if (ll->chars[i] == '\t') {  					// Tab display -					if (phasesDraw == PhasesDraw::one) { +					if (phasesDraw == PhasesDraw::One) {  						if (drawWhitespaceBackground && vsDraw.WhiteSpaceVisible(inIndentation)) -							textBack = vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE_BACK)->Opaque(); +							textBack = vsDraw.ElementColour(Element::WhiteSpaceBack)->Opaque();  						surface->FillRectangleAligned(rcSegment, Fill(textBack));  					} -					if (inIndentation && vsDraw.viewIndentationGuides == IndentView::real) { +					if (inIndentation && vsDraw.viewIndentationGuides == IndentView::Real) {  						for (int indentCount = static_cast<int>((ll->positions[i] + epsilon) / indentWidth);  							indentCount <= (ll->positions[i + 1] - epsilon) / indentWidth;  							indentCount++) { @@ -1992,12 +1995,12 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  							}  						}  					} -					if (vsDraw.viewWhitespace != WhiteSpace::invisible) { +					if (vsDraw.viewWhitespace != WhiteSpace::Invisible) {  						if (vsDraw.WhiteSpaceVisible(inIndentation)) {  							const PRectangle rcTab(rcSegment.left + 1, rcSegment.top + tabArrowHeight,  								rcSegment.right - 1, rcSegment.bottom - vsDraw.maxDescent);  							const int segmentTop = static_cast<int>(rcSegment.top) + vsDraw.lineHeight / 2; -							const ColourRGBA whiteSpaceFore = vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE).value_or(textFore); +							const ColourRGBA whiteSpaceFore = vsDraw.ElementColour(Element::WhiteSpace).value_or(textFore);  							if (!customDrawTabArrow)  								DrawTabArrow(surface, rcTab, segmentTop, vsDraw, Stroke(whiteSpaceFore, 1.0f));  							else @@ -2010,21 +2013,21 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  						// Using one font for all control characters so it can be controlled independently to ensure  						// the box goes around the characters tightly. Seems to be no way to work out what height  						// is taken by an individual character - internal leading gives varying results. -						const Font *ctrlCharsFont = vsDraw.styles[STYLE_CONTROLCHAR].font.get(); +						const Font *ctrlCharsFont = vsDraw.styles[StyleControlChar].font.get();  						const char cc[2] = { static_cast<char>(vsDraw.controlCharSymbol), '\0' };  						surface->DrawTextNoClip(rcSegment, ctrlCharsFont,  							rcSegment.top + vsDraw.maxAscent,  							cc, textBack, textFore);  					} else {  						DrawTextBlob(surface, vsDraw, rcSegment, ts.representation->stringRep, -							textBack, textFore, phasesDraw == PhasesDraw::one); +							textBack, textFore, phasesDraw == PhasesDraw::One);  					}  				}  			} else {  				// Normal text display  				if (vsDraw.styles[styleMain].visible) {  					const std::string_view text(&ll->chars[ts.start], i - ts.start + 1); -					if (phasesDraw != PhasesDraw::one) { +					if (phasesDraw != PhasesDraw::One) {  						surface->DrawTextTransparent(rcSegment, textFont,  							rcSegment.top + vsDraw.maxAscent, text, textFore);  					} else { @@ -2032,15 +2035,15 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  							rcSegment.top + vsDraw.maxAscent, text, textFore, textBack);  					}  				} -				if (vsDraw.viewWhitespace != WhiteSpace::invisible || -					(inIndentation && vsDraw.viewIndentationGuides != IndentView::none)) { +				if (vsDraw.viewWhitespace != WhiteSpace::Invisible || +					(inIndentation && vsDraw.viewIndentationGuides != IndentView::None)) {  					for (int cpos = 0; cpos <= i - ts.start; cpos++) {  						if (ll->chars[cpos + ts.start] == ' ') { -							if (vsDraw.viewWhitespace != WhiteSpace::invisible) { +							if (vsDraw.viewWhitespace != WhiteSpace::Invisible) {  								if (vsDraw.WhiteSpaceVisible(inIndentation)) {  									const XYPOSITION xmid = (ll->positions[cpos + ts.start] + ll->positions[cpos + ts.start + 1]) / 2; -									if ((phasesDraw == PhasesDraw::one) && drawWhitespaceBackground) { -										textBack = vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE_BACK)->Opaque(); +									if ((phasesDraw == PhasesDraw::One) && drawWhitespaceBackground) { +										textBack = vsDraw.ElementColour(Element::WhiteSpaceBack)->Opaque();  										const PRectangle rcSpace(  											ll->positions[cpos + ts.start] + xStart - static_cast<XYPOSITION>(subLineStart),  											rcSegment.top, @@ -2053,11 +2056,11 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  										rcSegment.top + vsDraw.lineHeight / 2, 0.0f, 0.0f);  									rcDot.right = rcDot.left + vsDraw.whitespaceSize;  									rcDot.bottom = rcDot.top + vsDraw.whitespaceSize; -									const ColourRGBA whiteSpaceFore = vsDraw.ElementColour(SC_ELEMENT_WHITE_SPACE).value_or(textFore); +									const ColourRGBA whiteSpaceFore = vsDraw.ElementColour(Element::WhiteSpace).value_or(textFore);  									surface->FillRectangleAligned(rcDot, Fill(whiteSpaceFore));  								}  							} -							if (inIndentation && vsDraw.viewIndentationGuides == IndentView::real) { +							if (inIndentation && vsDraw.viewIndentationGuides == IndentView::Real) {  								for (int indentCount = static_cast<int>((ll->positions[cpos + ts.start] + epsilon) / indentWidth);  									indentCount <= (ll->positions[cpos + ts.start + 1] - epsilon) / indentWidth;  									indentCount++) { @@ -2078,8 +2081,8 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  				PRectangle rcUL = rcSegment;  				rcUL.top = rcUL.top + vsDraw.maxAscent + 1;  				rcUL.bottom = rcUL.top + 1; -				if (vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE)) -					surface->FillRectangleAligned(rcUL, Fill(*vsDraw.ElementColour(SC_ELEMENT_HOT_SPOT_ACTIVE))); +				if (vsDraw.ElementColour(Element::HotSpotActive)) +					surface->FillRectangleAligned(rcUL, Fill(*vsDraw.ElementColour(Element::HotSpotActive)));  				else  					surface->FillRectangleAligned(rcUL, Fill(textFore));  			} else if (vsDraw.styles[styleMain].underline) { @@ -2096,7 +2099,7 @@ void EditView::DrawForeground(Surface *surface, const EditModel &model, const Vi  void EditView::DrawIndentGuidesOverEmpty(Surface *surface, const EditModel &model, const ViewStyle &vsDraw, const LineLayout *ll,  	Sci::Line line, Sci::Line lineVisible, PRectangle rcLine, int xStart, int subLine) { -	if ((vsDraw.viewIndentationGuides == IndentView::lookForward || vsDraw.viewIndentationGuides == IndentView::lookBoth) +	if ((vsDraw.viewIndentationGuides == IndentView::LookForward || vsDraw.viewIndentationGuides == IndentView::LookBoth)  		&& (subLine == 0)) {  		const Sci::Position posLineStart = model.pdoc->LineStart(line);  		int indentSpace = model.pdoc->GetLineIndentation(line); @@ -2112,12 +2115,12 @@ void EditView::DrawIndentGuidesOverEmpty(Surface *surface, const EditModel &mode  			xStartText = 100000;	// Don't limit to visible indentation on empty line  			// This line is empty, so use indentation of last line with text  			int indentLastWithText = model.pdoc->GetLineIndentation(lineLastWithText); -			const int isFoldHeader = LevelIsHeader(model.pdoc->GetLevel(lineLastWithText)); +			const int isFoldHeader = LevelIsHeader(model.pdoc->GetFoldLevel(lineLastWithText));  			if (isFoldHeader) {  				// Level is one more level than parent  				indentLastWithText += model.pdoc->IndentSize();  			} -			if (vsDraw.viewIndentationGuides == IndentView::lookForward) { +			if (vsDraw.viewIndentationGuides == IndentView::LookForward) {  				// In viLookForward mode, previous line only used if it is a fold header  				if (isFoldHeader) {  					indentSpace = std::max(indentSpace, indentLastWithText); @@ -2172,7 +2175,7 @@ void EditView::DrawLine(Surface *surface, const EditModel &model, const ViewStyl  		xStart += static_cast<int>(ll->wrapIndent);  	} -	if (phasesDraw != PhasesDraw::one) { +	if (phasesDraw != PhasesDraw::One) {  		if (FlagSet(phase, DrawPhase::back)) {  			DrawBackground(surface, model, vsDraw, ll, rcLine, lineRange, posLineStart, xStart,  				subLine, background); @@ -2195,8 +2198,8 @@ void EditView::DrawLine(Surface *surface, const EditModel &model, const ViewStyl  	}  	if (FlagSet(phase, DrawPhase::text)) { -		DrawTranslucentSelection(surface, model, vsDraw, ll, line, rcLine, subLine, lineRange, xStart, tabWidthMinimumPixels, Layer::under); -		DrawTranslucentLineState(surface, model, vsDraw, ll, line, rcLine, subLine, Layer::under); +		DrawTranslucentSelection(surface, model, vsDraw, ll, line, rcLine, subLine, lineRange, xStart, tabWidthMinimumPixels, Layer::UnderText); +		DrawTranslucentLineState(surface, model, vsDraw, ll, line, rcLine, subLine, Layer::UnderText);  		DrawForeground(surface, model, vsDraw, ll, lineVisible, rcLine, lineRange, posLineStart, xStart,  			subLine, background);  	} @@ -2213,7 +2216,7 @@ void EditView::DrawLine(Surface *surface, const EditModel &model, const ViewStyl  	DrawFoldDisplayText(surface, model, vsDraw, ll, line, xStart, rcLine, subLine, subLineStart, phase);  	DrawEOLAnnotationText(surface, model, vsDraw, ll, line, xStart, rcLine, subLine, subLineStart, phase); -	if (phasesDraw == PhasesDraw::one) { +	if (phasesDraw == PhasesDraw::One) {  		DrawEOL(surface, model, vsDraw, ll, rcLine, line, lineRange.end,  			xStart, subLine, subLineStart, background);  		if (vsDraw.IsLineFrameOpaque(model.caret.active, ll->containsCaret)) @@ -2223,35 +2226,35 @@ void EditView::DrawLine(Surface *surface, const EditModel &model, const ViewStyl  	}  	if (!hideSelection && FlagSet(phase, DrawPhase::selectionTranslucent)) { -		DrawTranslucentSelection(surface, model, vsDraw, ll, line, rcLine, subLine, lineRange, xStart, tabWidthMinimumPixels, Layer::over); +		DrawTranslucentSelection(surface, model, vsDraw, ll, line, rcLine, subLine, lineRange, xStart, tabWidthMinimumPixels, Layer::OverText);  	}  	if (FlagSet(phase, DrawPhase::lineTranslucent)) { -		DrawTranslucentLineState(surface, model, vsDraw, ll, line, rcLine, subLine, Layer::over); +		DrawTranslucentLineState(surface, model, vsDraw, ll, line, rcLine, subLine, Layer::OverText);  	}  }  static void DrawFoldLines(Surface *surface, const EditModel &model, const ViewStyle &vsDraw, Sci::Line line, PRectangle rcLine) {  	const bool expanded = model.pcs->GetExpanded(line); -	const int level = model.pdoc->GetLevel(line); -	const int levelNext = model.pdoc->GetLevel(line + 1); +	const FoldLevel level = model.pdoc->GetFoldLevel(line); +	const FoldLevel levelNext = model.pdoc->GetFoldLevel(line + 1);  	if (LevelIsHeader(level) &&  		(LevelNumber(level) < LevelNumber(levelNext))) {  		// Paint the line above the fold -		if ((expanded && (model.foldFlags & SC_FOLDFLAG_LINEBEFORE_EXPANDED)) +		if ((expanded && (FlagSet(model.foldFlags, FoldFlag::LineBeforeExpanded)))  			|| -			(!expanded && (model.foldFlags & SC_FOLDFLAG_LINEBEFORE_CONTRACTED))) { +			(!expanded && (FlagSet(model.foldFlags, FoldFlag::LineBeforeContracted)))) {  			PRectangle rcFoldLine = rcLine;  			rcFoldLine.bottom = rcFoldLine.top + 1; -			surface->FillRectangleAligned(rcFoldLine, Fill(vsDraw.styles[STYLE_DEFAULT].fore)); +			surface->FillRectangleAligned(rcFoldLine, Fill(vsDraw.styles[StyleDefault].fore));  		}  		// Paint the line below the fold -		if ((expanded && (model.foldFlags & SC_FOLDFLAG_LINEAFTER_EXPANDED)) +		if ((expanded && (FlagSet(model.foldFlags, FoldFlag::LineAfterExpanded)))  			|| -			(!expanded && (model.foldFlags & SC_FOLDFLAG_LINEAFTER_CONTRACTED))) { +			(!expanded && (FlagSet(model.foldFlags, FoldFlag::LineAfterContracted)))) {  			PRectangle rcFoldLine = rcLine;  			rcFoldLine.top = rcFoldLine.bottom - 1; -			surface->FillRectangleAligned(rcFoldLine, Fill(vsDraw.styles[STYLE_DEFAULT].fore)); +			surface->FillRectangleAligned(rcFoldLine, Fill(vsDraw.styles[StyleDefault].fore));  		}  	}  } @@ -2306,13 +2309,13 @@ void EditView::PaintText(Surface *surfaceWindow, const EditModel &model, PRectan  		double durCopy = 0.0;  		ElapsedPeriod epWhole;  #endif -		const bool bracesIgnoreStyle = ((vsDraw.braceHighlightIndicatorSet && (model.bracesMatchStyle == STYLE_BRACELIGHT)) || -			(vsDraw.braceBadLightIndicatorSet && (model.bracesMatchStyle == STYLE_BRACEBAD))); +		const bool bracesIgnoreStyle = ((vsDraw.braceHighlightIndicatorSet && (model.bracesMatchStyle == StyleBraceLight)) || +			(vsDraw.braceBadLightIndicatorSet && (model.bracesMatchStyle == StyleBraceBad)));  		Sci::Line lineDocPrevious = -1;	// Used to avoid laying out one document line multiple times  		std::shared_ptr<LineLayout> ll;  		std::vector<DrawPhase> phases; -		if ((phasesDraw == PhasesDraw::multiple) && !bufferedDraw) { +		if ((phasesDraw == PhasesDraw::Multiple) && !bufferedDraw) {  			for (DrawPhase phase = DrawPhase::back; phase <= DrawPhase::carets; phase = static_cast<DrawPhase>(static_cast<int>(phase) * 2)) {  				phases.push_back(phase);  			} @@ -2361,12 +2364,12 @@ void EditView::PaintText(Surface *surfaceWindow, const EditModel &model, PRectan  					ll->SetBracesHighlight(rangeLine, model.braces, static_cast<char>(model.bracesMatchStyle),  						static_cast<int>(model.highlightGuideColumn * vsDraw.spaceWidth), bracesIgnoreStyle); -					if (leftTextOverlap && (bufferedDraw || ((phasesDraw < PhasesDraw::multiple) && (FlagSet(phase, DrawPhase::back))))) { +					if (leftTextOverlap && (bufferedDraw || ((phasesDraw < PhasesDraw::Multiple) && (FlagSet(phase, DrawPhase::back))))) {  						// Clear the left margin  						PRectangle rcSpacer = rcLine;  						rcSpacer.right = rcSpacer.left;  						rcSpacer.left -= 1; -						surface->FillRectangleAligned(rcSpacer, Fill(vsDraw.styles[STYLE_DEFAULT].back)); +						surface->FillRectangleAligned(rcSpacer, Fill(vsDraw.styles[StyleDefault].back));  					}  					if (model.BidirectionalEnabled()) { @@ -2424,13 +2427,13 @@ void EditView::PaintText(Surface *surfaceWindow, const EditModel &model, PRectan  		rcBeyondEOF.right = rcBeyondEOF.right - ((vsDraw.marginInside) ? vsDraw.rightMarginWidth : 0);  		rcBeyondEOF.top = static_cast<XYPOSITION>((model.pcs->LinesDisplayed() - model.TopLineOfMain()) * vsDraw.lineHeight);  		if (rcBeyondEOF.top < rcBeyondEOF.bottom) { -			surfaceWindow->FillRectangleAligned(rcBeyondEOF, Fill(vsDraw.styles[STYLE_DEFAULT].back)); -			if (vsDraw.edgeState == EDGE_LINE) { +			surfaceWindow->FillRectangleAligned(rcBeyondEOF, Fill(vsDraw.styles[StyleDefault].back)); +			if (vsDraw.edgeState == EdgeVisualStyle::Line) {  				const int edgeX = static_cast<int>(vsDraw.theEdge.column * vsDraw.spaceWidth);  				rcBeyondEOF.left = static_cast<XYPOSITION>(edgeX + xStart);  				rcBeyondEOF.right = rcBeyondEOF.left + 1;  				surfaceWindow->FillRectangleAligned(rcBeyondEOF, Fill(vsDraw.theEdge.colour)); -			} else if (vsDraw.edgeState == EDGE_MULTILINE) { +			} else if (vsDraw.edgeState == EdgeVisualStyle::MultiLine) {  				for (size_t edge = 0; edge < vsDraw.theMultiEdge.size(); edge++) {  					if (vsDraw.theMultiEdge[edge].column >= 0) {  						const int edgeX = static_cast<int>(vsDraw.theMultiEdge[edge].column * vsDraw.spaceWidth); @@ -2463,7 +2466,7 @@ void EditView::FillLineRemainder(Surface *surface, const EditModel &model, const  	const std::optional<ColourRGBA> background = vsDraw.Background(model.pdoc->GetMark(line), model.caret.active, ll->containsCaret); -	if (eolInSelection && vsDraw.selection.eolFilled && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer == Layer::base)) { +	if (eolInSelection && vsDraw.selection.eolFilled && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer == Layer::Base)) {  		surface->FillRectangleAligned(rcArea, Fill(SelectionBackground(model, vsDraw, eolInSelection).Opaque()));  	} else {  		if (background) { @@ -2471,9 +2474,9 @@ void EditView::FillLineRemainder(Surface *surface, const EditModel &model, const  		} else if (vsDraw.styles[ll->styles[ll->numCharsInLine]].eolFilled) {  			surface->FillRectangleAligned(rcArea, Fill(vsDraw.styles[ll->styles[ll->numCharsInLine]].back));  		} else { -			surface->FillRectangleAligned(rcArea, Fill(vsDraw.styles[STYLE_DEFAULT].back)); +			surface->FillRectangleAligned(rcArea, Fill(vsDraw.styles[StyleDefault].back));  		} -		if (eolInSelection && vsDraw.selection.eolFilled && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::base)) { +		if (eolInSelection && vsDraw.selection.eolFilled && (line < model.pdoc->LinesTotal() - 1) && (vsDraw.selection.layer != Layer::Base)) {  			surface->FillRectangleAligned(rcArea, SelectionBackground(model, vsDraw, eolInSelection));  		}  	} @@ -2496,19 +2499,19 @@ static ColourRGBA InvertedLight(ColourRGBA orig) noexcept {  	return ColourRGBA(std::min(r, 0xffu), std::min(g, 0xffu), std::min(b, 0xffu));  } -Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Surface *surface, Surface *surfaceMeasure, +Sci::Position EditView::FormatRange(bool draw, const RangeToFormat *pfr, Surface *surface, Surface *surfaceMeasure,  	const EditModel &model, const ViewStyle &vs) {  	// Can't use measurements cached for screen  	posCache.Clear();  	ViewStyle vsPrint(vs); -	vsPrint.technology = SC_TECHNOLOGY_DEFAULT; +	vsPrint.technology = Technology::Default;  	// Modify the view style for printing as do not normally want any of the transient features to be printed  	// Printing supports only the line number margin.  	int lineNumberIndex = -1;  	for (size_t margin = 0; margin < vs.ms.size(); margin++) { -		if ((vsPrint.ms[margin].style == SC_MARGIN_NUMBER) && (vsPrint.ms[margin].width > 0)) { +		if ((vsPrint.ms[margin].style == MarginType::Number) && (vsPrint.ms[margin].width > 0)) {  			lineNumberIndex = static_cast<int>(margin);  		} else {  			vsPrint.ms[margin].width = 0; @@ -2517,8 +2520,8 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  	vsPrint.fixedColumnWidth = 0;  	vsPrint.zoomLevel = printParameters.magnification;  	// Don't show indentation guides -	// If this ever gets changed, cached pixmap would need to be recreated if technology != SC_TECHNOLOGY_DEFAULT -	vsPrint.viewIndentationGuides = IndentView::none; +	// If this ever gets changed, cached pixmap would need to be recreated if technology != Technology::Default +	vsPrint.viewIndentationGuides = IndentView::None;  	// Don't show the selection when printing  	vsPrint.elementColours.clear();  	vsPrint.elementBaseColours.clear(); @@ -2529,23 +2532,23 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  	// Set colours for printing according to users settings  	for (size_t sty = 0; sty < vsPrint.styles.size(); sty++) { -		if (printParameters.colourMode == SC_PRINT_INVERTLIGHT) { +		if (printParameters.colourMode == PrintOption::InvertLight) {  			vsPrint.styles[sty].fore = InvertedLight(vsPrint.styles[sty].fore);  			vsPrint.styles[sty].back = InvertedLight(vsPrint.styles[sty].back); -		} else if (printParameters.colourMode == SC_PRINT_BLACKONWHITE) { +		} else if (printParameters.colourMode == PrintOption::BlackOnWhite) {  			vsPrint.styles[sty].fore = ColourRGBA(0, 0, 0);  			vsPrint.styles[sty].back = ColourRGBA(0xff, 0xff, 0xff); -		} else if (printParameters.colourMode == SC_PRINT_COLOURONWHITE) { +		} else if (printParameters.colourMode == PrintOption::ColourOnWhite) {  			vsPrint.styles[sty].back = ColourRGBA(0xff, 0xff, 0xff); -		} else if (printParameters.colourMode == SC_PRINT_COLOURONWHITEDEFAULTBG) { -			if (sty <= STYLE_DEFAULT) { +		} else if (printParameters.colourMode == PrintOption::ColourOnWhiteDefaultBG) { +			if (sty <= StyleDefault) {  				vsPrint.styles[sty].back = ColourRGBA(0xff, 0xff, 0xff);  			}  		}  	} -	// White background for the line numbers if SC_PRINT_SCREENCOLOURS isn't used -	if (printParameters.colourMode != SC_PRINT_SCREENCOLOURS) -		vsPrint.styles[STYLE_LINENUMBER].back = ColourRGBA(0xff, 0xff, 0xff); +	// White background for the line numbers if PrintOption::ScreenColours isn't used +	if (printParameters.colourMode != PrintOption::ScreenColours) +		vsPrint.styles[StyleLineNumber].back = ColourRGBA(0xff, 0xff, 0xff);  	// Printing uses different margins, so reset screen margins  	vsPrint.leftMarginWidth = 0; @@ -2555,7 +2558,7 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  	// Determining width must happen after fonts have been realised in Refresh  	int lineNumberWidth = 0;  	if (lineNumberIndex >= 0) { -		lineNumberWidth = static_cast<int>(surfaceMeasure->WidthText(vsPrint.styles[STYLE_LINENUMBER].font.get(), +		lineNumberWidth = static_cast<int>(surfaceMeasure->WidthText(vsPrint.styles[StyleLineNumber].font.get(),  			"99999" lineNumberPrintSpace));  		vsPrint.ms[lineNumberIndex].width = lineNumberWidth;  		vsPrint.Refresh(*surfaceMeasure, model.pdoc->tabInChars);	// Recalculate fixedColumnWidth @@ -2570,7 +2573,7 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  		linePrintLast = linePrintMax;  	//Platform::DebugPrintf("Formatting lines=[%0d,%0d,%0d] top=%0d bottom=%0d line=%0d %0d\n",  	//      linePrintStart, linePrintLast, linePrintMax, pfr->rc.top, pfr->rc.bottom, vsPrint.lineHeight, -	//      surfaceMeasure->Height(vsPrint.styles[STYLE_LINENUMBER].font)); +	//      surfaceMeasure->Height(vsPrint.styles[StyleLineNumber].font));  	Sci::Position endPosPrint = model.pdoc->Length();  	if (linePrintLast < model.pdoc->LinesTotal())  		endPosPrint = model.pdoc->LineStart(linePrintLast + 1); @@ -2586,7 +2589,7 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  	Sci::Position nPrintPos = pfr->chrg.cpMin;  	int visibleLine = 0;  	int widthPrint = pfr->rc.right - pfr->rc.left - vsPrint.fixedColumnWidth; -	if (printParameters.wrapState == WrapMode::none) +	if (printParameters.wrapState == Wrap::None)  		widthPrint = LineLayout::wrapWidthInfinite;  	while (lineDoc <= linePrintLast && ypos < pfr->rc.bottom) { @@ -2635,12 +2638,12 @@ Sci::Position EditView::FormatRange(bool draw, const Sci_RangeToFormat *pfr, Sur  			rcNumber.right = rcNumber.left + lineNumberWidth;  			// Right justify  			rcNumber.left = rcNumber.right - surfaceMeasure->WidthText( -				vsPrint.styles[STYLE_LINENUMBER].font.get(), number); +				vsPrint.styles[StyleLineNumber].font.get(), number);  			surface->FlushCachedState(); -			surface->DrawTextNoClip(rcNumber, vsPrint.styles[STYLE_LINENUMBER].font.get(), +			surface->DrawTextNoClip(rcNumber, vsPrint.styles[StyleLineNumber].font.get(),  				static_cast<XYPOSITION>(ypos + vsPrint.maxAscent), number, -				vsPrint.styles[STYLE_LINENUMBER].fore, -				vsPrint.styles[STYLE_LINENUMBER].back); +				vsPrint.styles[StyleLineNumber].fore, +				vsPrint.styles[StyleLineNumber].back);  		}  		// Draw the line | 
