Compare commits

..

No commits in common. "0e3f7c8c1c3a85d7ee322aacf9c8f680415d55f8" and "0a8a8188cd073705947846386c5e9660b17d5ec2" have entirely different histories.

2 changed files with 32 additions and 20 deletions

View file

@ -990,30 +990,25 @@ fn send_goto_request(self: *Self, from: tp.pid_ref, file_path: []const u8, row:
} }
fn file_uri_to_path(uri: []const u8, file_path_buf: []u8) error{InvalidTargetURI}![]u8 { fn file_uri_to_path(uri: []const u8, file_path_buf: []u8) error{InvalidTargetURI}![]u8 {
const file_path = std.Uri.percentDecodeBackwards(file_path_buf, if (std.mem.eql(u8, uri[0..7], "file://")) return std.Uri.percentDecodeBackwards(file_path_buf, if (std.mem.eql(u8, uri[0..7], "file://"))
uri[7..] uri[7..]
else if (std.mem.eql(u8, uri[0..5], "file:")) else if (std.mem.eql(u8, uri[0..5], "file:"))
uri[5..] uri[5..]
else else
return error.InvalidTargetURI); return error.InvalidTargetURI);
return convert_path(file_path);
}
fn convert_path(file_path: []u8) []u8 {
if (builtin.os.tag == .windows) {
if (file_path[0] == '/') file_path = file_path[1..];
for (file_path, 0..) |c, i| if (c == '/') {
file_path[i] = '\\';
};
}
return file_path;
} }
fn navigate_to_location_link(from: tp.pid_ref, location_link: []const u8) (error{InvalidTargetURI} || LocationLinkError)!void { fn navigate_to_location_link(from: tp.pid_ref, location_link: []const u8) (error{InvalidTargetURI} || LocationLinkError)!void {
const location: LocationLink = try read_locationlink(location_link); const location: LocationLink = try read_locationlink(location_link);
if (location.targetUri == null or location.targetRange == null) return error.InvalidLocationLink; if (location.targetUri == null or location.targetRange == null) return error.InvalidLocationLink;
var file_path_buf: [std.fs.max_path_bytes]u8 = undefined; var file_path_buf: [std.fs.max_path_bytes]u8 = undefined;
const file_path = try file_uri_to_path(location.targetUri.?, &file_path_buf); var file_path = try file_uri_to_path(location.targetUri.?, &file_path_buf);
if (builtin.os.tag == .windows) {
if (file_path[0] == '/') file_path = file_path[1..];
for (file_path, 0..) |c, i| if (c == '/') {
file_path[i] = '\\';
};
}
if (location.targetSelectionRange) |sel| { if (location.targetSelectionRange) |sel| {
from.send(.{ "cmd", "navigate", .{ from.send(.{ "cmd", "navigate", .{
.file = file_path, .file = file_path,
@ -1139,7 +1134,13 @@ fn send_reference(tag: []const u8, to: tp.pid_ref, location_: []const u8, name:
const location: LocationLink = try read_locationlink(location_); const location: LocationLink = try read_locationlink(location_);
if (location.targetUri == null or location.targetRange == null) return error.InvalidLocationLink; if (location.targetUri == null or location.targetRange == null) return error.InvalidLocationLink;
var file_path_buf: [std.fs.max_path_bytes]u8 = undefined; var file_path_buf: [std.fs.max_path_bytes]u8 = undefined;
const file_path = try file_uri_to_path(location.targetUri.?, &file_path_buf); var file_path = try file_uri_to_path(location.targetUri.?, &file_path_buf);
if (builtin.os.tag == .windows) {
if (file_path[0] == '/') file_path = file_path[1..];
for (file_path, 0..) |c, i| if (c == '/') {
file_path[i] = '\\';
};
}
const line = try get_line_of_file(allocator, file_path, location.targetRange.?.start.line); const line = try get_line_of_file(allocator, file_path, location.targetRange.?.start.line);
defer allocator.free(line); defer allocator.free(line);
const file_path_ = if (file_path.len > name.len and std.mem.eql(u8, name, file_path[0..name.len])) const file_path_ = if (file_path.len > name.len and std.mem.eql(u8, name, file_path[0..name.len]))
@ -1406,7 +1407,13 @@ fn send_symbol_information(to: tp.pid_ref, file_path: []const u8, item: []const
if (location) |location_| { if (location) |location_| {
if (location_.targetUri == null or location_.targetRange == null) return error.InvalidSymbolInformationField; if (location_.targetUri == null or location_.targetRange == null) return error.InvalidSymbolInformationField;
var file_path_buf: [std.fs.max_path_bytes]u8 = undefined; var file_path_buf: [std.fs.max_path_bytes]u8 = undefined;
const file_path_ = try file_uri_to_path(location_.targetUri.?, &file_path_buf); var file_path_ = try file_uri_to_path(location_.targetUri.?, &file_path_buf);
if (builtin.os.tag == .windows) {
if (file_path_[0] == '/') file_path_ = file_path_[1..];
for (file_path_, 0..) |c, i| if (c == '/') {
file_path_[i] = '\\';
};
}
fp = file_path_; fp = file_path_;
to.send(.{ "cmd", "add_symbol_information", .{ fp, name, parent_name, kind, location_.targetRange.?.start.line, location_.targetRange.?.start.character, location_.targetRange.?.end.line, location_.targetRange.?.end.character, tags[0..len_tags_], location_.targetSelectionRange.?.start.line, location_.targetSelectionRange.?.start.character, location_.targetSelectionRange.?.end.line, location_.targetSelectionRange.?.end.character, deprecated, location_.targetUri } }) catch |e| { to.send(.{ "cmd", "add_symbol_information", .{ fp, name, parent_name, kind, location_.targetRange.?.start.line, location_.targetRange.?.start.character, location_.targetRange.?.end.line, location_.targetRange.?.end.character, tags[0..len_tags_], location_.targetSelectionRange.?.start.line, location_.targetSelectionRange.?.start.character, location_.targetSelectionRange.?.end.line, location_.targetSelectionRange.?.end.character, deprecated, location_.targetUri } }) catch |e| {
std.log.err("send add_symbol_information failed: {t}", .{e}); std.log.err("send add_symbol_information failed: {t}", .{e});
@ -1615,7 +1622,13 @@ pub fn rename_symbol(self: *Self, from: tp.pid_ref, file_path: []const u8, row:
try cbor.writeArrayHeader(w, renames.items.len); try cbor.writeArrayHeader(w, renames.items.len);
for (renames.items) |rename| { for (renames.items) |rename| {
var file_path_buf: [std.fs.max_path_bytes]u8 = undefined; var file_path_buf: [std.fs.max_path_bytes]u8 = undefined;
const file_path_ = try file_uri_to_path(rename.uri, &file_path_buf); var file_path_ = try file_uri_to_path(rename.uri, &file_path_buf);
if (builtin.os.tag == .windows) {
if (file_path_[0] == '/') file_path_ = file_path_[1..];
for (file_path_, 0..) |c, i| if (c == '/') {
file_path_[i] = '\\';
};
}
const line = try get_line_of_file(allocator, self_.file_path, rename.range.start.line); const line = try get_line_of_file(allocator, self_.file_path, rename.range.start.line);
try cbor.writeValue(w, .{ try cbor.writeValue(w, .{
file_path_, file_path_,
@ -2632,7 +2645,7 @@ pub fn process_git(self: *Self, parent: tp.pid_ref, m: tp.message) (OutOfMemoryE
try self.loaded(parent); try self.loaded(parent);
} else if (try m.match(.{ tp.any, tp.any, "workspace_path", tp.extract(&value) })) { } else if (try m.match(.{ tp.any, tp.any, "workspace_path", tp.extract(&value) })) {
if (self.workspace) |p| self.allocator.free(p); if (self.workspace) |p| self.allocator.free(p);
self.workspace = convert_path(try self.allocator.dupe(u8, value)); self.workspace = try self.allocator.dupe(u8, value);
self.state.workspace_path = .done; self.state.workspace_path = .done;
self.state.workspace_files = .running; self.state.workspace_files = .running;
git.workspace_files(@intFromPtr(self)) catch { git.workspace_files(@intFromPtr(self)) catch {
@ -2663,7 +2676,7 @@ pub fn process_git(self: *Self, parent: tp.pid_ref, m: tp.message) (OutOfMemoryE
}; };
const file_type: []const u8, const file_icon: []const u8, const file_color: u24 = guess_file_type(path); const file_type: []const u8, const file_icon: []const u8, const file_color: u24 = guess_file_type(path);
(try self.pending.addOne(self.allocator)).* = .{ (try self.pending.addOne(self.allocator)).* = .{
.path = convert_path(try self.allocator.dupe(u8, path)), .path = try self.allocator.dupe(u8, path),
.type = file_type, .type = file_type,
.icon = file_icon, .icon = file_icon,
.color = file_color, .color = file_color,
@ -2679,7 +2692,7 @@ pub fn process_git(self: *Self, parent: tp.pid_ref, m: tp.message) (OutOfMemoryE
self.longest_new_or_modified_file_path = @max(self.longest_new_or_modified_file_path, path.len); self.longest_new_or_modified_file_path = @max(self.longest_new_or_modified_file_path, path.len);
const file_type: []const u8, const file_icon: []const u8, const file_color: u24 = guess_file_type(path); const file_type: []const u8, const file_icon: []const u8, const file_color: u24 = guess_file_type(path);
(try self.new_or_modified_files.addOne(self.allocator)).* = .{ (try self.new_or_modified_files.addOne(self.allocator)).* = .{
.path = convert_path(try self.allocator.dupe(u8, path)), .path = try self.allocator.dupe(u8, path),
.type = file_type, .type = file_type,
.icon = file_icon, .icon = file_icon,
.color = file_color, .color = file_color,

View file

@ -90,7 +90,6 @@ pub fn start(a_: std.mem.Allocator, root_path_: []const u8, entry_handler: Entry
} }
const filtered_dirs = [_][]const u8{ const filtered_dirs = [_][]const u8{
"AppData",
".cache", ".cache",
".cargo", ".cargo",
".git", ".git",