Merge branch 'master' into zig-0.14
This commit is contained in:
commit
ce6df051fb
1 changed files with 9 additions and 2 deletions
|
@ -4020,12 +4020,18 @@ pub const Editor = struct {
|
||||||
const b = try self.buf_for_update();
|
const b = try self.buf_for_update();
|
||||||
var root = b.root;
|
var root = b.root;
|
||||||
for (self.cursels.items) |*cursel_| if (cursel_.*) |*cursel| {
|
for (self.cursels.items) |*cursel_| if (cursel_.*) |*cursel| {
|
||||||
|
var indent_extra = true;
|
||||||
const smart_brace_indent = blk: {
|
const smart_brace_indent = blk: {
|
||||||
var sel = Selection.from_cursor(&cursel.cursor);
|
var sel = Selection.from_cursor(&cursel.cursor);
|
||||||
move_cursor_left(root, &sel.begin, self.metrics) catch break :blk false;
|
move_cursor_left(root, &sel.begin, self.metrics) catch break :blk false;
|
||||||
const egc_left, _, _ = sel.end.egc_at(root, self.metrics) catch break :blk false;
|
const egc_left, _, _ = sel.end.egc_at(root, self.metrics) catch break :blk false;
|
||||||
const egc_right, _, _ = sel.begin.egc_at(root, self.metrics) catch break :blk false;
|
const egc_right, _, _ = sel.begin.egc_at(root, self.metrics) catch break :blk false;
|
||||||
break :blk std.mem.eql(u8, egc_right, "{") and std.mem.eql(u8, egc_left, "}");
|
if (std.mem.eql(u8, egc_right, "[") and std.mem.eql(u8, egc_left, "]")) {
|
||||||
|
indent_extra = false;
|
||||||
|
break :blk true;
|
||||||
|
}
|
||||||
|
break :blk (std.mem.eql(u8, egc_right, "{") and std.mem.eql(u8, egc_left, "}")) or
|
||||||
|
(std.mem.eql(u8, egc_right, "(") and std.mem.eql(u8, egc_left, ")"));
|
||||||
};
|
};
|
||||||
|
|
||||||
root = try self.cursel_smart_insert_line(root, cursel, b.allocator);
|
root = try self.cursel_smart_insert_line(root, cursel, b.allocator);
|
||||||
|
@ -4034,7 +4040,8 @@ pub const Editor = struct {
|
||||||
const cursor = cursel.cursor;
|
const cursor = cursel.cursor;
|
||||||
root = try self.cursel_smart_insert_line(root, cursel, b.allocator);
|
root = try self.cursel_smart_insert_line(root, cursel, b.allocator);
|
||||||
cursel.cursor = cursor;
|
cursel.cursor = cursor;
|
||||||
root = try self.indent_cursel(root, cursel, b.allocator);
|
if (indent_extra)
|
||||||
|
root = try self.indent_cursel(root, cursel, b.allocator);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
try self.update_buf(root);
|
try self.update_buf(root);
|
||||||
|
|
Loading…
Add table
Reference in a new issue