Refactor references to pointers

This commit is contained in:
Krzosa Karol
2024-08-13 10:38:57 +02:00
parent c0877bfe1d
commit 9cac98d961
11 changed files with 135 additions and 135 deletions

View File

@@ -30,7 +30,7 @@ void OffsetAllLinesForward(Buffer *buffer, Int line, Int *_offset) {
void UpdateLines(Buffer *buffer, Range range, String16 string) { void UpdateLines(Buffer *buffer, Range range, String16 string) {
ProfileFunction(); ProfileFunction();
Array<Int> &ls = buffer->line_starts; Array<Int> &ls = buffer->line_starts;
Int min_line_number = PosToLine(*buffer, range.min); Int min_line_number = PosToLine(buffer, range.min);
Assert(min_line_number < ls.len); Assert(min_line_number < ls.len);
// Update lines remove // Update lines remove
{ {
@@ -72,7 +72,7 @@ void UpdateLines(Buffer *buffer, Range range, String16 string) {
void ValidateLineStarts(Buffer *buffer) { void ValidateLineStarts(Buffer *buffer) {
Int line = 0; Int line = 0;
for (Int i = 0; i < buffer->len; i += 1) { for (Int i = 0; i < buffer->len; i += 1) {
Int l = PosToLine(*buffer, i); Int l = PosToLine(buffer, i);
Assert(l == line); Assert(l == line);
if (buffer->data[i] == L'\n') line += 1; if (buffer->data[i] == L'\n') line += 1;
} }
@@ -111,7 +111,7 @@ void IKnowWhatImDoing_ReplaceText(Buffer *buffer, Range range, String16 string)
} }
void IKnowWhatImDoing_Append(Buffer *buffer, String16 string) { void IKnowWhatImDoing_Append(Buffer *buffer, String16 string) {
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), string); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), string);
} }
void IKnowWhatImDoing_Append(Buffer *buffer, String string) { void IKnowWhatImDoing_Append(Buffer *buffer, String string) {
@@ -123,5 +123,5 @@ void IKnowWhatImDoing_Appendf(Buffer *buffer, const char *fmt, ...) {
Scratch scratch(buffer->line_starts.allocator); Scratch scratch(buffer->line_starts.allocator);
STRING_FORMAT(scratch, fmt, string); STRING_FORMAT(scratch, fmt, string);
String16 string16 = ToString16(scratch, string); String16 string16 = ToString16(scratch, string);
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), string16); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), string16);
} }

View File

@@ -33,7 +33,7 @@ Array<FuzzyPair> FuzzySearchLines(Allocator allocator, Buffer *buffer, Int line_
if (line_max < 0 || line_min > buffer->line_starts.len) return {}; if (line_max < 0 || line_min > buffer->line_starts.len) return {};
Array<FuzzyPair> ratings = {allocator}; Array<FuzzyPair> ratings = {allocator};
for (Int i = line_min; i < line_max; i += 1) { for (Int i = line_min; i < line_max; i += 1) {
String16 s = GetLineStringWithoutNL(*buffer, i); String16 s = GetLineStringWithoutNL(buffer, i);
int64_t rating = FuzzyRate(s, needle); int64_t rating = FuzzyRate(s, needle);
Add(&ratings, {i, rating}); Add(&ratings, {i, rating});
} }

View File

@@ -14,37 +14,37 @@ Range Rng(Int a = 0) {
return result; return result;
} }
String16 GetString(Buffer &buffer, Range range = {0, INT64_MAX}) { String16 GetString(Buffer *buffer, Range range = {0, INT64_MAX}) {
range.min = Clamp(range.min, (Int)0, buffer.len); range.min = Clamp(range.min, (Int)0, buffer->len);
range.max = Clamp(range.max, (Int)0, buffer.len); range.max = Clamp(range.max, (Int)0, buffer->len);
String16 result = {(wchar_t *)buffer.data + range.min, GetSize(range)}; String16 result = {(wchar_t *)buffer->data + range.min, GetSize(range)};
return result; return result;
} }
Int Clamp(const Buffer &buffer, Int pos) { Int Clamp(const Buffer *buffer, Int pos) {
Int result = Clamp(pos, (Int)0, buffer.len); Int result = Clamp(pos, (Int)0, buffer->len);
return result; return result;
} }
Range Clamp(const Buffer &buffer, Range range) { Range Clamp(const Buffer *buffer, Range range) {
Range result = {}; Range result = {};
result.min = Clamp(buffer, range.min); result.min = Clamp(buffer, range.min);
result.max = Clamp(buffer, range.max); result.max = Clamp(buffer, range.max);
return result; return result;
} }
Range GetEndAsRange(Buffer &buffer) { Range GetEndAsRange(Buffer *buffer) {
Range result = {buffer.len, buffer.len}; Range result = {buffer->len, buffer->len};
return result; return result;
} }
Range GetBeginAsRange(Buffer &buffer) { Range GetBeginAsRange(Buffer *buffer) {
Range result = {0, 0}; Range result = {0, 0};
return result; return result;
} }
Range GetRange(Buffer &buffer) { Range GetRange(Buffer *buffer) {
Range result = {0, buffer.len}; Range result = {0, buffer->len};
return result; return result;
} }
@@ -113,8 +113,8 @@ Caret SetFrontWithAnchor(Caret caret, Range anchor, Int p) {
return caret; return caret;
} }
bool InBounds(const Buffer &buffer, Int pos) { bool InBounds(const Buffer *buffer, Int pos) {
bool result = pos >= 0 && pos < buffer.len; bool result = pos >= 0 && pos < buffer->len;
return result; return result;
} }
@@ -160,55 +160,55 @@ Range operator-=(Range &range, Int value) {
return range; return range;
} }
Int LastLine(Buffer &buffer) { Int LastLine(Buffer *buffer) {
Int result = buffer.line_starts.len - 1; Int result = buffer->line_starts.len - 1;
return result; return result;
} }
const Int LAST_LINE = INT64_MAX; const Int LAST_LINE = INT64_MAX;
Range GetLineRange(Buffer &buffer, Int line, Int *end_of_buffer = NULL) { Range GetLineRange(Buffer *buffer, Int line, Int *end_of_buffer = NULL) {
Range result = {buffer.line_starts[line], buffer.len}; Range result = {buffer->line_starts[line], buffer->len};
if (line + 1 < buffer.line_starts.len) { if (line + 1 < buffer->line_starts.len) {
result.max = buffer.line_starts[line + 1]; result.max = buffer->line_starts[line + 1];
} else if (end_of_buffer) { } else if (end_of_buffer) {
*end_of_buffer = 1; *end_of_buffer = 1;
} }
return result; return result;
} }
Range GetLineRangeWithoutNL(Buffer &buffer, Int line) { Range GetLineRangeWithoutNL(Buffer *buffer, Int line) {
Int end_of_buffer = 0; Int end_of_buffer = 0;
Range line_range = GetLineRange(buffer, line, &end_of_buffer); Range line_range = GetLineRange(buffer, line, &end_of_buffer);
line_range.max = line_range.max - 1 + end_of_buffer; line_range.max = line_range.max - 1 + end_of_buffer;
return line_range; return line_range;
} }
String16 GetLineString(Buffer &buffer, Int line, Int *end_of_buffer = NULL) { String16 GetLineString(Buffer *buffer, Int line, Int *end_of_buffer = NULL) {
Range range = GetLineRange(buffer, line, end_of_buffer); Range range = GetLineRange(buffer, line, end_of_buffer);
String16 string = GetString(buffer, range); String16 string = GetString(buffer, range);
return string; return string;
} }
String16 GetLineStringWithoutNL(Buffer &buffer, Int line) { String16 GetLineStringWithoutNL(Buffer *buffer, Int line) {
Range range = GetLineRangeWithoutNL(buffer, line); Range range = GetLineRangeWithoutNL(buffer, line);
String16 string = GetString(buffer, range); String16 string = GetString(buffer, range);
return string; return string;
} }
Int PosToLine(Buffer &buffer, Int pos) { Int PosToLine(Buffer *buffer, Int pos) {
Add(&buffer.line_starts, buffer.len + 1); Add(&buffer->line_starts, buffer->len + 1);
// binary search // binary search
Int low = 0; Int low = 0;
// -2 here because we use 2 indices and combine them into one line range so we // -2 here because we use 2 indices and combine them into one line range so we
// don't want to access last item since that would index past array. // don't want to access last item since that would index past array.
Int high = buffer.line_starts.len - 2; Int high = buffer->line_starts.len - 2;
Int result = 0; Int result = 0;
while (low <= high) { while (low <= high) {
Int mid = low + (high - low) / 2; Int mid = low + (high - low) / 2;
Range range = {buffer.line_starts[mid], buffer.line_starts[mid + 1]}; Range range = {buffer->line_starts[mid], buffer->line_starts[mid + 1]};
if (pos >= range.min && pos < range.max) { if (pos >= range.min && pos < range.max) {
result = mid; result = mid;
break; break;
@@ -221,11 +221,11 @@ Int PosToLine(Buffer &buffer, Int pos) {
} }
} }
Pop(&buffer.line_starts); Pop(&buffer->line_starts);
return result; return result;
} }
XY PosToXY(Buffer &buffer, Int pos) { XY PosToXY(Buffer *buffer, Int pos) {
Int line = PosToLine(buffer, pos); Int line = PosToLine(buffer, pos);
Range line_range = GetLineRange(buffer, line); Range line_range = GetLineRange(buffer, line);
Int col = pos - line_range.min; Int col = pos - line_range.min;
@@ -233,23 +233,23 @@ XY PosToXY(Buffer &buffer, Int pos) {
return result; return result;
} }
Int XYToPos(Buffer &buffer, XY xy) { Int XYToPos(Buffer *buffer, XY xy) {
xy.line = Clamp(xy.line, (Int)0, buffer.line_starts.len - 1); xy.line = Clamp(xy.line, (Int)0, buffer->line_starts.len - 1);
Range line_range = GetLineRange(buffer, xy.line); Range line_range = GetLineRange(buffer, xy.line);
Int pos = Clamp(xy.col + line_range.min, line_range.min, line_range.max); Int pos = Clamp(xy.col + line_range.min, line_range.min, line_range.max);
return pos; return pos;
} }
Int XYToPosWithoutNL(Buffer &buffer, XY xy) { Int XYToPosWithoutNL(Buffer *buffer, XY xy) {
xy.line = Clamp(xy.line, (Int)0, buffer.line_starts.len - 1); xy.line = Clamp(xy.line, (Int)0, buffer->line_starts.len - 1);
Int end_of_buffer = 0; Int end_of_buffer = 0;
Range line_range = GetLineRange(buffer, xy.line, &end_of_buffer); Range line_range = GetLineRange(buffer, xy.line, &end_of_buffer);
Int pos = Clamp(xy.col + line_range.min, line_range.min, line_range.max - 1 + end_of_buffer); Int pos = Clamp(xy.col + line_range.min, line_range.min, line_range.max - 1 + end_of_buffer);
return pos; return pos;
} }
Int XYToPosErrorOutOfBounds(Buffer &buffer, XY xy) { Int XYToPosErrorOutOfBounds(Buffer *buffer, XY xy) {
if (xy.line < 0 || xy.line >= buffer.line_starts.len) return -1; if (xy.line < 0 || xy.line >= buffer->line_starts.len) return -1;
Range line_range = GetLineRange(buffer, xy.line); Range line_range = GetLineRange(buffer, xy.line);
Int pos = xy.col + line_range.min; Int pos = xy.col + line_range.min;
if (pos < line_range.min || pos > line_range.max) return -1; if (pos < line_range.min || pos > line_range.max) return -1;
@@ -360,29 +360,29 @@ Int GetPrevWordStart(Buffer *buffer, Int pos) {
Int GetLineStart(Buffer *buffer, Int pos) { Int GetLineStart(Buffer *buffer, Int pos) {
pos = Clamp(pos, (Int)0, buffer->len); pos = Clamp(pos, (Int)0, buffer->len);
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Range range = GetLineRangeWithoutNL(*buffer, line); Range range = GetLineRangeWithoutNL(buffer, line);
return range.min; return range.min;
} }
Int GetLineEnd(Buffer *buffer, Int pos) { Int GetLineEnd(Buffer *buffer, Int pos) {
pos = Clamp(pos, (Int)0, buffer->len); pos = Clamp(pos, (Int)0, buffer->len);
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Range range = GetLineRangeWithoutNL(*buffer, line); Range range = GetLineRangeWithoutNL(buffer, line);
return range.max; return range.max;
} }
Int GetFullLineStart(Buffer *buffer, Int pos) { Int GetFullLineStart(Buffer *buffer, Int pos) {
pos = Clamp(pos, (Int)0, buffer->len); pos = Clamp(pos, (Int)0, buffer->len);
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Range range = GetLineRange(*buffer, line); Range range = GetLineRange(buffer, line);
return range.min; return range.min;
} }
Int GetFullLineEnd(Buffer *buffer, Int pos) { Int GetFullLineEnd(Buffer *buffer, Int pos) {
pos = Clamp(pos, (Int)0, buffer->len); pos = Clamp(pos, (Int)0, buffer->len);
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Range range = GetLineRange(*buffer, line); Range range = GetLineRange(buffer, line);
return range.max; return range.max;
} }
@@ -396,9 +396,9 @@ Int GetBufferStart(Buffer *buffer) {
Int GetNextEmptyLineStart(Buffer *buffer, Int pos) { Int GetNextEmptyLineStart(Buffer *buffer, Int pos) {
Int result = pos; Int result = pos;
Int next_line = PosToLine(*buffer, pos) + 1; Int next_line = PosToLine(buffer, pos) + 1;
for (Int line = next_line; line < buffer->line_starts.len; line += 1) { for (Int line = next_line; line < buffer->line_starts.len; line += 1) {
Range line_range = GetLineRangeWithoutNL(*buffer, line); Range line_range = GetLineRangeWithoutNL(buffer, line);
result = line_range.min; result = line_range.min;
bool whitespace_line = true; bool whitespace_line = true;
@@ -415,9 +415,9 @@ Int GetNextEmptyLineStart(Buffer *buffer, Int pos) {
Int GetPrevEmptyLineStart(Buffer *buffer, Int pos) { Int GetPrevEmptyLineStart(Buffer *buffer, Int pos) {
Int result = pos; Int result = pos;
Int next_line = PosToLine(*buffer, pos) - 1; Int next_line = PosToLine(buffer, pos) - 1;
for (Int line = next_line; line >= 0; line -= 1) { for (Int line = next_line; line >= 0; line -= 1) {
Range line_range = GetLineRangeWithoutNL(*buffer, line); Range line_range = GetLineRangeWithoutNL(buffer, line);
result = line_range.min; result = line_range.min;
bool whitespace_line = true; bool whitespace_line = true;
@@ -521,8 +521,8 @@ Range EncloseFullLine(Buffer *buffer, Int pos) {
} }
Int OffsetByLine(Buffer *buffer, Int pos, Int line_offset) { Int OffsetByLine(Buffer *buffer, Int pos, Int line_offset) {
XY xy = PosToXY(*buffer, pos); XY xy = PosToXY(buffer, pos);
Int result = XYToPosWithoutNL(*buffer, {xy.col, xy.line + line_offset}); Int result = XYToPosWithoutNL(buffer, {xy.col, xy.line + line_offset});
return result; return result;
} }
@@ -537,7 +537,7 @@ Int GetPrevChar(Buffer *buffer, Int pos) {
} }
Int GetLineIndent(Buffer *buffer, Int line) { Int GetLineIndent(Buffer *buffer, Int line) {
String16 string = GetLineStringWithoutNL(*buffer, line); String16 string = GetLineStringWithoutNL(buffer, line);
Int indent = 0; Int indent = 0;
for (Int i = 0; i < string.len; i += 1) { for (Int i = 0; i < string.len; i += 1) {
if (IsWhitespace(string.data[i])) { if (IsWhitespace(string.data[i])) {
@@ -550,14 +550,14 @@ Int GetLineIndent(Buffer *buffer, Int line) {
} }
Int GetIndentAtPos(Buffer *buffer, Int pos) { Int GetIndentAtPos(Buffer *buffer, Int pos) {
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Int result = GetLineIndent(buffer, line); Int result = GetLineIndent(buffer, line);
return result; return result;
} }
Range GetIndentRangeAtPos(Buffer *buffer, Int pos) { Range GetIndentRangeAtPos(Buffer *buffer, Int pos) {
Int line = PosToLine(*buffer, pos); Int line = PosToLine(buffer, pos);
Int indent = GetLineIndent(buffer, line); Int indent = GetLineIndent(buffer, line);
Range range = GetLineRangeWithoutNL(*buffer, line); Range range = GetLineRangeWithoutNL(buffer, line);
return {range.min, range.min + indent}; return {range.min, range.min + indent};
} }

View File

@@ -15,7 +15,7 @@ void SaveHistoryBeforeApplyEdits(Buffer *buffer, Array<HistoryEntry> *stack, Arr
// Make reverse edits // Make reverse edits
For(entry->edits) { For(entry->edits) {
Range new_range = {it.range.min, it.range.min + it.string.len}; Range new_range = {it.range.min, it.range.min + it.string.len};
String16 string = GetString(*buffer, it.range); String16 string = GetString(buffer, it.range);
it.string = Copy(sys_allocator, string); it.string = Copy(sys_allocator, string);
it.range = new_range; it.range = new_range;
} }

View File

@@ -1,12 +1,12 @@
void LoadBigText(Buffer *buffer, int size = 5000000) { void LoadBigText(Buffer *buffer, int size = 5000000) {
for (int i = 0; i < size; i += 1) { for (int i = 0; i < size; i += 1) {
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), L"Line number and another meme or something of the sort which is here or there frankly somewhere\n"); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), L"Line number and another meme or something of the sort which is here or there frankly somewhere\n");
} }
} }
void LoadBigLine(Buffer *buffer, int size = 5000000) { void LoadBigLine(Buffer *buffer, int size = 5000000) {
for (int i = 0; i < size; i += 1) { for (int i = 0; i < size; i += 1) {
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), L"Line number and another meme or something of the sort which is here or there frankly somewhere"); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), L"Line number and another meme or something of the sort which is here or there frankly somewhere");
} }
} }
@@ -20,7 +20,7 @@ void LoadTextA(Buffer *buffer) {
for (int i = 0; i < 1000; i += 1) { for (int i = 0; i < 1000; i += 1) {
String s = Format(scratch, "line1: %d line2: %d line3: %d line4: %d line5: %d line6: %d line1: %d line2: %d line3: %d line4: %d line5: %d line6: %d\r\n", i, i, i, i, i, i, i, i, i, i, i, i); String s = Format(scratch, "line1: %d line2: %d line3: %d line4: %d line5: %d line6: %d line1: %d line2: %d line3: %d line4: %d line5: %d line6: %d\r\n", i, i, i, i, i, i, i, i, i, i, i, i);
String16 s16 = ToString16(scratch, s); String16 s16 = ToString16(scratch, s);
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), s16); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), s16);
} }
} }
@@ -155,5 +155,5 @@ CJK Unified Ideographs
丿 乿 ... 丿 乿 ...
Hangul Syllables Hangul Syllables
갿 걿 ...)==="; 갿 걿 ...)===";
IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(*buffer), ToString16(scratch, text)); IKnowWhatImDoing_ReplaceText(buffer, GetEndAsRange(buffer), ToString16(scratch, text));
} }

View File

@@ -119,7 +119,7 @@ Int ScreenSpaceToBufferPos(Window *window, View *view, Buffer *buffer, Vec2I mou
Vec2I mworld = mouse - window->document_rect.min + view->scroll; Vec2I mworld = mouse - window->document_rect.min + view->scroll;
Vec2I pos = mworld / Vec2I{FontCharSpacing, FontLineSpacing}; Vec2I pos = mworld / Vec2I{FontCharSpacing, FontLineSpacing};
XY xy = {(Int)(pos.x), (Int)(pos.y)}; XY xy = {(Int)(pos.x), (Int)(pos.y)};
Int result = XYToPosWithoutNL(*buffer, xy); Int result = XYToPosWithoutNL(buffer, xy);
return result; return result;
} }
@@ -127,7 +127,7 @@ Int ScreenSpaceToBufferPosErrorOutOfBounds(Window *window, View *view, Buffer *b
Vec2I mworld = mouse - window->document_rect.min + view->scroll; Vec2I mworld = mouse - window->document_rect.min + view->scroll;
Vec2I pos = mworld / Vec2I{FontCharSpacing, FontLineSpacing}; Vec2I pos = mworld / Vec2I{FontCharSpacing, FontLineSpacing};
XY xy = {(Int)(pos.x), (Int)(pos.y)}; XY xy = {(Int)(pos.x), (Int)(pos.y)};
Int result = XYToPosErrorOutOfBounds(*buffer, xy); Int result = XYToPosErrorOutOfBounds(buffer, xy);
return result; return result;
} }
@@ -143,7 +143,7 @@ void MouseExecWord(Event event) {
if (InBounds(active.view->carets[0].range, p)) { if (InBounds(active.view->carets[0].range, p)) {
enclose = active.view->carets[0].range; enclose = active.view->carets[0].range;
} }
String16 string = GetString(*active.buffer, enclose); String16 string = GetString(active.buffer, enclose);
Command_EvalLua(active.view, string); Command_EvalLua(active.view, string);
} }
} }
@@ -180,7 +180,7 @@ void MouseLoadWord(Event event) {
if (p != -1) { if (p != -1) {
Range enclose = EncloseLoadWord(active.buffer, p); Range enclose = EncloseLoadWord(active.buffer, p);
if (InBounds(active.view->carets[0].range, p)) enclose = active.view->carets[0].range; if (InBounds(active.view->carets[0].range, p)) enclose = active.view->carets[0].range;
String16 string = GetString(*active.buffer, enclose); String16 string = GetString(active.buffer, enclose);
active.view->carets.len = 1; active.view->carets.len = 1;
active.view->carets[0] = MakeCaret(p); active.view->carets[0] = MakeCaret(p);
@@ -332,7 +332,7 @@ bool GlobalCommand(Event event) {
IterRemove(active.view->carets) { IterRemove(active.view->carets) {
IterRemovePrepare(active.view->carets); IterRemovePrepare(active.view->carets);
if (InBounds(it.range, p)) { if (InBounds(it.range, p)) {
String16 string = GetString(*active.buffer, it.range); String16 string = GetString(active.buffer, it.range);
SaveStringInClipboard(string); SaveStringInClipboard(string);
remove_item = true; remove_item = true;
@@ -342,9 +342,9 @@ bool GlobalCommand(Event event) {
if (active.view->carets.len == 0) Add(&active.view->carets, MakeCaret(saved_front)); if (active.view->carets.len == 0) Add(&active.view->carets, MakeCaret(saved_front));
if (saved_front == -1) { if (saved_front == -1) {
Int line = PosToLine(*active.buffer, p); Int line = PosToLine(active.buffer, p);
Range line_range = GetLineRangeWithoutNL(*active.buffer, line); Range line_range = GetLineRangeWithoutNL(active.buffer, line);
String16 string = GetString(*active.buffer, line_range); String16 string = GetString(active.buffer, line_range);
SaveStringInClipboard(string); SaveStringInClipboard(string);
} }
} }
@@ -484,7 +484,7 @@ void Command_Append(View *view, String16 string, bool scroll_to_end_if_cursor_on
bool scroll_to_end = false; bool scroll_to_end = false;
if (scroll_to_end_if_cursor_on_last_line) { if (scroll_to_end_if_cursor_on_last_line) {
Int line = PosToLine(*buffer, GetFront(view->carets[0])); Int line = PosToLine(buffer, GetFront(view->carets[0]));
if (line == buffer->line_starts.len - 1) scroll_to_end = true; if (line == buffer->line_starts.len - 1) scroll_to_end = true;
} }
@@ -497,12 +497,12 @@ void Command_Append(View *view, String16 string, bool scroll_to_end_if_cursor_on
} }
}; };
Command_SelectRangeOneCursor(view, GetEndAsRange(*buffer)); Command_SelectRangeOneCursor(view, GetEndAsRange(buffer));
Command_Replace(view, string); Command_Replace(view, string);
Command_Replace(view, L"\n"); Command_Replace(view, L"\n");
if (scroll_to_end) { if (scroll_to_end) {
view->carets[0] = MakeCaret(GetEndAsRange(*buffer).min); view->carets[0] = MakeCaret(GetEndAsRange(buffer).min);
} }
} }

View File

@@ -35,15 +35,15 @@ void Command_Copy(View *view) {
// First, if there is no selection - select the entire line // First, if there is no selection - select the entire line
For(view->carets) { For(view->carets) {
if (GetSize(it.range) == 0) { if (GetSize(it.range) == 0) {
Int line = PosToLine(*buffer, it.range.min); Int line = PosToLine(buffer, it.range.min);
Range line_range = GetLineRange(*buffer, line); Range line_range = GetLineRange(buffer, line);
it.range = line_range; it.range = line_range;
} }
} }
Array<String16> caret_strings = {sys_allocator}; Array<String16> caret_strings = {sys_allocator};
For(view->carets) { For(view->carets) {
String16 string = GetString(*buffer, it.range); String16 string = GetString(buffer, it.range);
String16 copy = Copy(sys_allocator, string); String16 copy = Copy(sys_allocator, string);
Add(&SavedClipboardCarets, copy); Add(&SavedClipboardCarets, copy);
} }

View File

@@ -8,16 +8,16 @@ void Command_MoveCursorsByPageSize(Window *window, int direction, bool shift = f
if (direction == DIR_UP) y = -y; if (direction == DIR_UP) y = -y;
For(set.view->carets) { For(set.view->carets) {
XY xy = PosToXY(*set.buffer, GetFront(it)); XY xy = PosToXY(set.buffer, GetFront(it));
if (direction == DIR_DOWN && xy.line == set.buffer->line_starts.len - 1) { if (direction == DIR_DOWN && xy.line == set.buffer->line_starts.len - 1) {
Range line_range = GetLineRange(*set.buffer, xy.line); Range line_range = GetLineRange(set.buffer, xy.line);
xy.col = line_range.max - line_range.min; xy.col = line_range.max - line_range.min;
} else if (direction == DIR_UP && xy.line == 0) { } else if (direction == DIR_UP && xy.line == 0) {
xy.col = 0; xy.col = 0;
} }
xy.line += y; xy.line += y;
Int pos = XYToPos(*set.buffer, xy); Int pos = XYToPos(set.buffer, xy);
if (shift) { if (shift) {
it = SetFront(it, pos); it = SetFront(it, pos);
} else { } else {
@@ -166,10 +166,10 @@ void Command_MoveLine(View *view, int direction) {
MergeCarets(view); MergeCarets(view);
Array<XYPair> saved_xy = {scratch}; Array<XYPair> saved_xy = {scratch};
For(view->carets) { For(view->carets) {
Add(&saved_xy, {PosToXY(*buffer, GetFront(it)), PosToXY(*buffer, GetBack(it))}); Add(&saved_xy, {PosToXY(buffer, GetFront(it)), PosToXY(buffer, GetBack(it))});
Range lines_to_move_range = {GetFullLineStart(buffer, it.range.min), GetFullLineEnd(buffer, it.range.max)}; Range lines_to_move_range = {GetFullLineStart(buffer, it.range.min), GetFullLineEnd(buffer, it.range.max)};
String16 string = GetString(*buffer, lines_to_move_range); String16 string = GetString(buffer, lines_to_move_range);
string = Copy(scratch, string); string = Copy(scratch, string);
AddEdit(&edits, lines_to_move_range, {}); AddEdit(&edits, lines_to_move_range, {});
@@ -193,8 +193,8 @@ void Command_MoveLine(View *view, int direction) {
XYPair &xypair = saved_xy[i]; XYPair &xypair = saved_xy[i];
xypair.front.line += line_offset; xypair.front.line += line_offset;
xypair.back.line += line_offset; xypair.back.line += line_offset;
Int front = XYToPos(*buffer, xypair.front); Int front = XYToPos(buffer, xypair.front);
Int back = XYToPos(*buffer, xypair.back); Int back = XYToPos(buffer, xypair.back);
caret = MakeCaret(front, back); caret = MakeCaret(front, back);
} }
@@ -225,9 +225,9 @@ void Command_DuplicateLine(View *view, int direction) {
Array<Edit> edits = {scratch}; Array<Edit> edits = {scratch};
For(view->carets) { For(view->carets) {
Int line = PosToLine(*buffer, it.range.min); Int line = PosToLine(buffer, it.range.min);
Range range = GetLineRange(*buffer, line); Range range = GetLineRange(buffer, line);
String16 string = Copy(scratch, GetString(*buffer, range)); String16 string = Copy(scratch, GetString(buffer, range));
Int pos = direction == DIR_UP ? range.min : range.max; Int pos = direction == DIR_UP ? range.min : range.max;
AddEdit(&edits, Rng(pos), string); AddEdit(&edits, Rng(pos), string);
} }
@@ -269,8 +269,8 @@ Array<Range> GetSelectedLinesSorted(Allocator allocator, View *view) {
Array<Range> result = {allocator}; Array<Range> result = {allocator};
For(caret_copy) { For(caret_copy) {
Int min_line = PosToLine(*buffer, it.range.min); Int min_line = PosToLine(buffer, it.range.min);
Int max_line = PosToLine(*buffer, it.range.max); Int max_line = PosToLine(buffer, it.range.max);
Range line_range = {min_line, max_line + 1}; Range line_range = {min_line, max_line + 1};
if (result.len == 0) { if (result.len == 0) {
@@ -298,13 +298,13 @@ void Command_IndentSelectedLines(View *view, bool shift = false) {
Array<Range> line_ranges_to_indent = GetSelectedLinesSorted(scratch, view); Array<Range> line_ranges_to_indent = GetSelectedLinesSorted(scratch, view);
For(line_ranges_to_indent) { For(line_ranges_to_indent) {
for (Int i = it.min; i < it.max; i += 1) { for (Int i = it.min; i < it.max; i += 1) {
Range pos_range_of_line = GetLineRange(*buffer, i); Range pos_range_of_line = GetLineRange(buffer, i);
if (!shift) { if (!shift) {
String16 whitespace_string = {L" ", StyleIndentSize}; String16 whitespace_string = {L" ", StyleIndentSize};
AddEdit(&edits, {pos_range_of_line.min, pos_range_of_line.min}, whitespace_string); AddEdit(&edits, {pos_range_of_line.min, pos_range_of_line.min}, whitespace_string);
} else { } else {
String16 string = GetString(*buffer, pos_range_of_line); String16 string = GetString(buffer, pos_range_of_line);
Int whitespace_len = 0; Int whitespace_len = 0;
for (Int i = 0; i < StyleIndentSize && i < string.len && string.data[i] == ' '; i += 1) { for (Int i = 0; i < StyleIndentSize && i < string.len && string.data[i] == ' '; i += 1) {
whitespace_len += 1; whitespace_len += 1;
@@ -332,7 +332,7 @@ void Command_TrimTrailingWhitespace(View *view, bool dont_trim_lines_with_cursor
Int range_index = FindRangeByPos(lines_to_skip_triming, i); Int range_index = FindRangeByPos(lines_to_skip_triming, i);
if (range_index != -1) continue; if (range_index != -1) continue;
Range range = GetLineRangeWithoutNL(*buffer, i); Range range = GetLineRangeWithoutNL(buffer, i);
Int whitespace_end = range.max; Int whitespace_end = range.max;
for (; whitespace_end > range.min; whitespace_end -= 1) { for (; whitespace_end > range.min; whitespace_end -= 1) {
U16 w = buffer->data[whitespace_end - 1]; U16 w = buffer->data[whitespace_end - 1];
@@ -362,7 +362,7 @@ void Command_ConvertLineEndings(View *view, bool dont_trim_lines_with_cursor) {
Int range_index = FindRangeByPos(lines_to_skip_triming, i); Int range_index = FindRangeByPos(lines_to_skip_triming, i);
if (range_index != -1) continue; if (range_index != -1) continue;
Range range = GetLineRangeWithoutNL(*buffer, i); Range range = GetLineRangeWithoutNL(buffer, i);
wchar_t cr = GetChar(buffer, range.max - 1); wchar_t cr = GetChar(buffer, range.max - 1);
wchar_t lf = GetChar(buffer, range.max); wchar_t lf = GetChar(buffer, range.max);
if (cr == L'\r' && lf == L'\n') { if (cr == L'\r' && lf == L'\n') {
@@ -384,14 +384,14 @@ void SaveBuffer(View *view) {
// { // {
// Scratch scratch; // Scratch scratch;
// String16 string16 = GetString(*buffer); // String16 string16 = GetString(buffer);
// String string = ToString(scratch, string16); // String string = ToString(scratch, string16);
// Buffer *temp_buffer = ExecAndWait(scratch, "clang-format", GetDir(buffer), string); // Buffer *temp_buffer = ExecAndWait(scratch, "clang-format", GetDir(buffer), string);
// Command_ReplaceWithoutMovingCarets(view, GetRange(*buffer), {temp_buffer->str, temp_buffer->len}); // Command_ReplaceWithoutMovingCarets(view, GetRange(buffer), {temp_buffer->str, temp_buffer->len});
// } // }
Scratch scratch; Scratch scratch;
String16 string16 = GetString(*buffer); String16 string16 = GetString(buffer);
String string = ToString(scratch, string16); String string = ToString(scratch, string16);
bool success = WriteFile(buffer->name, string); bool success = WriteFile(buffer->name, string);
@@ -412,17 +412,17 @@ void Command_KillSelectedLines(View *view) {
Array<Range> lines = GetSelectedLinesSorted(scratch, view); Array<Range> lines = GetSelectedLinesSorted(scratch, view);
For(lines) { For(lines) {
Range add_range = GetLineRange(*buffer, it.min); Range add_range = GetLineRange(buffer, it.min);
for (Int i = it.min + 1; i < it.max; i += 1) { for (Int i = it.min + 1; i < it.max; i += 1) {
Range line_range = GetLineRange(*buffer, i); Range line_range = GetLineRange(buffer, i);
add_range.max = Max(line_range.max, add_range.max); add_range.max = Max(line_range.max, add_range.max);
} }
AddEdit(&edits, add_range, L""); AddEdit(&edits, add_range, L"");
} }
For(view->carets) { For(view->carets) {
Int line = PosToLine(*buffer, it.range.min); Int line = PosToLine(buffer, it.range.min);
Range range = GetLineRange(*buffer, line); Range range = GetLineRange(buffer, line);
it.range.min = it.range.max = range.min; it.range.min = it.range.max = range.min;
} }
@@ -467,7 +467,7 @@ void Command_Delete(View *view, int direction, bool ctrl = false) {
void Command_SelectAll(View *view, String16 needle) { void Command_SelectAll(View *view, String16 needle) {
Buffer *buffer = GetBuffer(view->active_buffer); Buffer *buffer = GetBuffer(view->active_buffer);
String16 string_buffer = GetString(*buffer); String16 string_buffer = GetString(buffer);
for (Int pos = 0;;) { for (Int pos = 0;;) {
Int index = 0; Int index = 0;
@@ -492,7 +492,7 @@ void Command_CreateCursorVertical(View *_view, int direction) {
Scratch scratch; Scratch scratch;
Array<Caret> arr = {scratch}; Array<Caret> arr = {scratch};
For(view.carets) { For(view.carets) {
if (PosToLine(*buffer, it.range.min) == PosToLine(*buffer, it.range.max)) { if (PosToLine(buffer, it.range.min) == PosToLine(buffer, it.range.max)) {
Int f = OffsetByLine(buffer, GetFront(it), line_offset); Int f = OffsetByLine(buffer, GetFront(it), line_offset);
Int b = OffsetByLine(buffer, GetBack(it), line_offset); Int b = OffsetByLine(buffer, GetBack(it), line_offset);
Add(&arr, MakeCaret(f, b)); Add(&arr, MakeCaret(f, b));
@@ -527,7 +527,7 @@ void MergeCarets(View *view) {
ProfileFunction(); ProfileFunction();
Buffer *buffer = GetBuffer(view->active_buffer); Buffer *buffer = GetBuffer(view->active_buffer);
For(view->carets) it.range = Clamp(*buffer, it.range); For(view->carets) it.range = Clamp(buffer, it.range);
Caret first_caret = view->carets.data[0]; Caret first_caret = view->carets.data[0];
Scratch scratch; Scratch scratch;
@@ -555,14 +555,14 @@ void MergeCarets(View *view) {
Caret FindPrev(Buffer *buffer, String16 needle, Caret caret) { Caret FindPrev(Buffer *buffer, String16 needle, Caret caret) {
Int pos = GetFront(caret); Int pos = GetFront(caret);
String16 medium = GetString(*buffer, {0, pos}); String16 medium = GetString(buffer, {0, pos});
Caret result = caret; Caret result = caret;
Int index = 0; Int index = 0;
if (Seek(medium, needle, &index, SeekFlag_MatchFindLast)) { if (Seek(medium, needle, &index, SeekFlag_MatchFindLast)) {
result = MakeCaret(index, index + needle.len); result = MakeCaret(index, index + needle.len);
} else { } else {
medium = GetString(*buffer); medium = GetString(buffer);
if (Seek(medium, needle, &index, SeekFlag_MatchFindLast)) { if (Seek(medium, needle, &index, SeekFlag_MatchFindLast)) {
result = MakeCaret(index, index + needle.len); result = MakeCaret(index, index + needle.len);
} }
@@ -573,14 +573,14 @@ Caret FindPrev(Buffer *buffer, String16 needle, Caret caret) {
Caret FindNext(Buffer *buffer, String16 needle, Caret caret) { Caret FindNext(Buffer *buffer, String16 needle, Caret caret) {
Int pos = GetFront(caret); Int pos = GetFront(caret);
String16 medium = GetString(*buffer, {pos, INT64_MAX}); String16 medium = GetString(buffer, {pos, INT64_MAX});
Caret result = caret; Caret result = caret;
Int index = 0; Int index = 0;
if (Seek(medium, needle, &index)) { if (Seek(medium, needle, &index)) {
result = MakeCaret(pos + index + needle.len, pos + index); result = MakeCaret(pos + index + needle.len, pos + index);
} else { } else {
medium = GetString(*buffer); medium = GetString(buffer);
if (Seek(medium, needle, &index)) { if (Seek(medium, needle, &index)) {
result = MakeCaret(index + needle.len, index); result = MakeCaret(index + needle.len, index);
} }
@@ -596,7 +596,7 @@ void Command_IdentedNewLine(View *view) {
MergeCarets(view); MergeCarets(view);
For(view->carets) { For(view->carets) {
Int front = GetFront(it); Int front = GetFront(it);
Int line = PosToLine(*buffer, front); Int line = PosToLine(buffer, front);
Int indent = GetLineIndent(buffer, line); Int indent = GetLineIndent(buffer, line);
String string = Format(scratch, "\n%.*s", (int)indent, " "); String string = Format(scratch, "\n%.*s", (int)indent, " ");
String16 string16 = ToString16(scratch, string); String16 string16 = ToString16(scratch, string);
@@ -625,12 +625,12 @@ void Command_GotoNextInList(Window *window, Int line_offset = 1) {
Buffer *buffer_goto = GetBuffer(view_goto->active_buffer); Buffer *buffer_goto = GetBuffer(view_goto->active_buffer);
int64_t pos = GetFront(view_goto->carets[0]); int64_t pos = GetFront(view_goto->carets[0]);
Int line = PosToLine(*buffer_goto, pos); Int line = PosToLine(buffer_goto, pos);
bool opened = false; bool opened = false;
for (Int i = line + line_offset; i >= 0 && i < buffer_goto->line_starts.len; i += line_offset) { for (Int i = line + line_offset; i >= 0 && i < buffer_goto->line_starts.len; i += line_offset) {
Range line_range = GetLineRangeWithoutNL(*buffer_goto, line + line_offset); Range line_range = GetLineRangeWithoutNL(buffer_goto, line + line_offset);
String16 line = GetString(*buffer_goto, line_range); String16 line = GetString(buffer_goto, line_range);
view_goto->carets[0] = MakeCaret(line_range.min); view_goto->carets[0] = MakeCaret(line_range.min);
line = Trim(line); line = Trim(line);
@@ -655,14 +655,14 @@ void Command_FuzzySort(View *view, String16 needle) {
Buffer *temp_buffer = CreateTempBuffer(scratch, buffer->cap); Buffer *temp_buffer = CreateTempBuffer(scratch, buffer->cap);
For(ratings) { For(ratings) {
String16 s = GetLineStringWithoutNL(*buffer, it.index); String16 s = GetLineStringWithoutNL(buffer, it.index);
if (s.len == 0) continue; if (s.len == 0) continue;
IKnowWhatImDoing_ReplaceText(temp_buffer, GetEndAsRange(*temp_buffer), s); IKnowWhatImDoing_ReplaceText(temp_buffer, GetEndAsRange(temp_buffer), s);
IKnowWhatImDoing_ReplaceText(temp_buffer, GetEndAsRange(*temp_buffer), L"\n"); IKnowWhatImDoing_ReplaceText(temp_buffer, GetEndAsRange(temp_buffer), L"\n");
} }
Command_SelectEntireBuffer(view); Command_SelectEntireBuffer(view);
Command_Replace(view, GetString(*temp_buffer)); Command_Replace(view, GetString(temp_buffer));
view->carets.len = 1; view->carets.len = 1;
view->carets[0] = MakeCaret({}); view->carets[0] = MakeCaret({});
@@ -829,7 +829,7 @@ void WindowCommand(Event event, Window *window, View *view) {
} }
if (Ctrl(SDLK_D)) { if (Ctrl(SDLK_D)) {
String16 string = GetString(*buffer, view->carets[0].range); String16 string = GetString(buffer, view->carets[0].range);
Caret caret = FindNext(buffer, string, view->carets[0]); Caret caret = FindNext(buffer, string, view->carets[0]);
Insert(&view->carets, caret, 0); Insert(&view->carets, caret, 0);
MergeCarets(view); MergeCarets(view);
@@ -893,14 +893,14 @@ void WindowCommand(Event event, Window *window, View *view) {
Caret caret = view->carets[0]; Caret caret = view->carets[0];
Range range = caret.range; Range range = caret.range;
if (GetSize(caret.range) == 0) range = EncloseExecWord(buffer, GetFront(caret)); if (GetSize(caret.range) == 0) range = EncloseExecWord(buffer, GetFront(caret));
String16 string = GetString(*buffer, range); String16 string = GetString(buffer, range);
Command_EvalLua(view, string); Command_EvalLua(view, string);
} else if (Ctrl(SDLK_Q)) { } else if (Ctrl(SDLK_Q)) {
Caret caret = view->carets[0]; Caret caret = view->carets[0];
Range range = caret.range; Range range = caret.range;
if (GetSize(caret.range) == 0) range = EncloseLoadWord(buffer, GetFront(caret)); if (GetSize(caret.range) == 0) range = EncloseLoadWord(buffer, GetFront(caret));
String16 string = GetString(*buffer, range); String16 string = GetString(buffer, range);
window->active_goto_list = view->id; window->active_goto_list = view->id;
Open(string); Open(string);
@@ -917,7 +917,7 @@ void UpdateScroll(Window *window, bool update_caret_scrolling) {
if (update_caret_scrolling) { if (update_caret_scrolling) {
Caret c = set.view->carets[0]; Caret c = set.view->carets[0];
Int front = GetFront(c); Int front = GetFront(c);
XY xy = PosToXY(*set.buffer, front); XY xy = PosToXY(set.buffer, front);
Rect2I visible = GetVisibleCells(window); Rect2I visible = GetVisibleCells(window);
Vec2I visible_cells = GetSize(visible); Vec2I visible_cells = GetSize(visible);
@@ -947,7 +947,7 @@ void UpdateScroll(Window *window, bool update_caret_scrolling) {
// Clip scroll // Clip scroll
{ {
Int last_line = LastLine(*set.buffer); Int last_line = LastLine(set.buffer);
set.view->scroll.y = Clamp(set.view->scroll.y, (Int)0, Max((Int)0, (last_line - 1) * FontLineSpacing)); set.view->scroll.y = Clamp(set.view->scroll.y, (Int)0, Max((Int)0, (last_line - 1) * FontLineSpacing));
// @note: // @note:

View File

@@ -67,7 +67,7 @@ void Open(String path) {
View *view = WindowOpenBufferView(main.window, file_path); View *view = WindowOpenBufferView(main.window, file_path);
Buffer *buffer = GetBuffer(view->active_buffer); Buffer *buffer = GetBuffer(view->active_buffer);
if (line != -1 && col != -1) { if (line != -1 && col != -1) {
Int pos = XYToPos(*buffer, {col - 1, line - 1}); Int pos = XYToPos(buffer, {col - 1, line - 1});
view->carets[0] = MakeCaret(pos); view->carets[0] = MakeCaret(pos);
} }
UpdateScroll(main.window, true); UpdateScroll(main.window, true);
@@ -301,7 +301,7 @@ void UpdateLua() {
Buffer *lua_buffer = GetBuffer(LuaBufferID); Buffer *lua_buffer = GetBuffer(LuaBufferID);
if (lua_buffer->dirty == false && lua_buffer->change_id != LuaBufferChangeID) { if (lua_buffer->dirty == false && lua_buffer->change_id != LuaBufferChangeID) {
Scratch scratch; Scratch scratch;
String16 string16 = GetString(*lua_buffer); String16 string16 = GetString(lua_buffer);
String string = ToString(scratch, string16); String string = ToString(scratch, string16);
if (luaL_dostring(LuaState, string.data) == LUA_OK) { if (luaL_dostring(LuaState, string.data) == LUA_OK) {
if (lua_isstring(LuaState, -1)) { if (lua_isstring(LuaState, -1)) {

View File

@@ -10,7 +10,7 @@ void UpdateDebugBuffer() {
Scratch scratch; Scratch scratch;
String s = Format(scratch, "wid: %d\nvid: %d\nbid: %d\nframe: %lld\n", (int)main.window->id.id, (int)main.view->id.id, (int)main.buffer->id.id, (long long)FrameID); String s = Format(scratch, "wid: %d\nvid: %d\nbid: %d\nframe: %lld\n", (int)main.window->id.id, (int)main.view->id.id, (int)main.buffer->id.id, (long long)FrameID);
String16 string = ToString16(scratch, s); String16 string = ToString16(scratch, s);
IKnowWhatImDoing_ReplaceText(buffer, GetRange(*buffer), string); IKnowWhatImDoing_ReplaceText(buffer, GetRange(buffer), string);
float xmouse, ymouse; float xmouse, ymouse;
SDL_GetMouseState(&xmouse, &ymouse); SDL_GetMouseState(&xmouse, &ymouse);
@@ -30,7 +30,7 @@ void ReplaceTitleBarData(Window *window) {
BSet main = GetMainSet(window); BSet main = GetMainSet(window);
Scratch scratch; Scratch scratch;
Caret caret = main.view->carets[0]; Caret caret = main.view->carets[0];
XY xy = PosToXY(*main.buffer, GetFront(caret)); XY xy = PosToXY(main.buffer, GetFront(caret));
Array<Caret> caret_copy = Copy(GetSystemAllocator(), view->carets); Array<Caret> caret_copy = Copy(GetSystemAllocator(), view->carets);
defer { defer {
@@ -38,17 +38,17 @@ void ReplaceTitleBarData(Window *window) {
view->carets = caret_copy; view->carets = caret_copy;
}; };
String16 buffer_string = GetString(*buffer); String16 buffer_string = GetString(buffer);
Range replace_range = {0, buffer->len}; Range replace_range = {0, buffer->len};
if (!Seek(buffer_string, L" |", &replace_range.max)) { if (!Seek(buffer_string, L" |", &replace_range.max)) {
Command_SelectRangeOneCursor(view, GetEndAsRange(*buffer)); Command_SelectRangeOneCursor(view, GetEndAsRange(buffer));
Array<Edit> edits = Command_ReplaceEx(scratch, view, L" |"); Array<Edit> edits = Command_ReplaceEx(scratch, view, L" |");
AdjustCarets(edits, &caret_copy); AdjustCarets(edits, &caret_copy);
} }
String s = Format(scratch, "%.*s:%lld:%lld", FmtString(main.buffer->name), (long long)xy.line + 1ll, (long long)xy.col + 1ll); String s = Format(scratch, "%.*s:%lld:%lld", FmtString(main.buffer->name), (long long)xy.line + 1ll, (long long)xy.col + 1ll);
String16 string = ToString16(scratch, s); String16 string = ToString16(scratch, s);
String16 string_to_replace = GetString(*buffer, replace_range); String16 string_to_replace = GetString(buffer, replace_range);
if (string_to_replace != string) { if (string_to_replace != string) {
Command_SelectRangeOneCursor(view, replace_range); Command_SelectRangeOneCursor(view, replace_range);
Array<Edit> edits = Command_ReplaceEx(scratch, view, string); Array<Edit> edits = Command_ReplaceEx(scratch, view, string);

View File

@@ -45,7 +45,7 @@ void DrawVisibleText(Window *window, Color tint) {
Rect2I visible = GetVisibleCells(window); Rect2I visible = GetVisibleCells(window);
for (Int line_index = visible.min.y; line_index < visible.max.y && line_index >= 0 && line_index < buffer->line_starts.len; line_index += 1) { for (Int line_index = visible.min.y; line_index < visible.max.y && line_index >= 0 && line_index < buffer->line_starts.len; line_index += 1) {
String16 line_string = GetLineString(*buffer, line_index); String16 line_string = GetLineString(buffer, line_index);
Vec2I pos = {visible.min.x * (Int)FontCharSpacing, line_index * (Int)FontLineSpacing}; Vec2I pos = {visible.min.x * (Int)FontCharSpacing, line_index * (Int)FontLineSpacing};
pos -= view->scroll; pos -= view->scroll;
@@ -90,8 +90,8 @@ void DrawCaret(Window *window, XY xy, float size, Color color) {
} }
void DrawUnderline(Window *window, View *view, Buffer *buffer, Range range, Color color, Int size = 1) { void DrawUnderline(Window *window, View *view, Buffer *buffer, Range range, Color color, Int size = 1) {
XY xy_min = PosToXY(*buffer, range.min); XY xy_min = PosToXY(buffer, range.min);
XY xy_max = PosToXY(*buffer, range.max); XY xy_max = PosToXY(buffer, range.max);
// @todo: maybe consider underlining multiple lines but then we would need to consider // @todo: maybe consider underlining multiple lines but then we would need to consider
// optimizing and so on // optimizing and so on
@@ -135,8 +135,8 @@ void DrawWindow(Window *window, Event &event) {
BeginProfileScope(draw_caret_selection); BeginProfileScope(draw_caret_selection);
Rect2I visible = GetVisibleCells(window); Rect2I visible = GetVisibleCells(window);
For(view->carets) { For(view->carets) {
XY min = PosToXY(*buffer, it.range.min); XY min = PosToXY(buffer, it.range.min);
XY max = PosToXY(*buffer, it.range.max); XY max = PosToXY(buffer, it.range.max);
if (visible.min.y > max.line) continue; if (visible.min.y > max.line) continue;
if (visible.max.y < min.line) continue; if (visible.max.y < min.line) continue;
@@ -144,7 +144,7 @@ void DrawWindow(Window *window, Event &event) {
// //
// Draw selection // Draw selection
for (Int line = visible.min.y; line <= visible.max.y && line >= 0 && line < buffer->line_starts.len; line += 1) { for (Int line = visible.min.y; line <= visible.max.y && line >= 0 && line < buffer->line_starts.len; line += 1) {
String16 line_string = GetLineString(*buffer, line); String16 line_string = GetLineString(buffer, line);
for (Int col = visible.min.x; col < visible.max.x && col >= 0 && col < line_string.len; col += 1) { for (Int col = visible.min.x; col < visible.max.x && col >= 0 && col < line_string.len; col += 1) {
bool a = line > min.line && line < max.line; bool a = line > min.line && line < max.line;
@@ -172,7 +172,7 @@ void DrawWindow(Window *window, Event &event) {
// //
// Draw highlight // Draw highlight
Int front = GetFront(it); Int front = GetFront(it);
XY fxy = PosToXY(*buffer, front); XY fxy = PosToXY(buffer, front);
Vec2I w = XYToWorldPos(view, XYLine(fxy.line)); Vec2I w = XYToWorldPos(view, XYLine(fxy.line));
w -= view->scroll; w -= view->scroll;
w += window->document_rect.min; w += window->document_rect.min;
@@ -219,7 +219,7 @@ void DrawWindow(Window *window, Event &event) {
if (is_active) { if (is_active) {
For(view->carets) { For(view->carets) {
Int front = GetFront(it); Int front = GetFront(it);
XY fxy = PosToXY(*buffer, front); XY fxy = PosToXY(buffer, front);
if (fxy.col >= visible.min.x && fxy.col < visible.max.x && fxy.line >= visible.min.y && fxy.line <= visible.max.y) { if (fxy.col >= visible.min.x && fxy.col < visible.max.x && fxy.line >= visible.min.y && fxy.line <= visible.max.y) {
bool main_caret = &it == &view->carets.data[0]; bool main_caret = &it == &view->carets.data[0];
DrawCaret(window, fxy, 0.3f, main_caret ? color_main_caret : color_sub_caret); DrawCaret(window, fxy, 0.3f, main_caret ? color_main_caret : color_sub_caret);