fix: normalize away './' path prefixes
This commit is contained in:
		
							parent
							
								
									5b23998376
								
							
						
					
					
						commit
						e053a0dcf4
					
				
					 5 changed files with 53 additions and 10 deletions
				
			
		|  | @ -743,6 +743,7 @@ pub fn build_exe( | ||||||
|     tests.root_module.addImport("color", color_mod); |     tests.root_module.addImport("color", color_mod); | ||||||
|     tests.root_module.addImport("tui", tui_mod); |     tests.root_module.addImport("tui", tui_mod); | ||||||
|     tests.root_module.addImport("command", command_mod); |     tests.root_module.addImport("command", command_mod); | ||||||
|  |     tests.root_module.addImport("project_manager", project_manager_mod); | ||||||
|     // b.installArtifact(tests); |     // b.installArtifact(tests); | ||||||
| 
 | 
 | ||||||
|     const test_run_cmd = b.addRunArtifact(tests); |     const test_run_cmd = b.addRunArtifact(tests); | ||||||
|  |  | ||||||
|  | @ -11,6 +11,7 @@ const git = @import("git"); | ||||||
| const file_type_config = @import("file_type_config"); | const file_type_config = @import("file_type_config"); | ||||||
| const builtin = @import("builtin"); | const builtin = @import("builtin"); | ||||||
| 
 | 
 | ||||||
|  | const project_manager = @import("project_manager.zig"); | ||||||
| const LSP = @import("LSP.zig"); | const LSP = @import("LSP.zig"); | ||||||
| const walk_tree = @import("walk_tree.zig"); | const walk_tree = @import("walk_tree.zig"); | ||||||
| 
 | 
 | ||||||
|  | @ -182,12 +183,12 @@ pub fn restore_state_v1(self: *Self, data: []const u8) !void { | ||||||
|     var files = try cbor.decodeArrayHeader(&iter); |     var files = try cbor.decodeArrayHeader(&iter); | ||||||
|     tp.trace(tp.channel.debug, .{ "restore_state_v1", "files", files }); |     tp.trace(tp.channel.debug, .{ "restore_state_v1", "files", files }); | ||||||
|     while (files > 0) : (files -= 1) { |     while (files > 0) : (files -= 1) { | ||||||
|         var path: []const u8 = undefined; |         var path_: []const u8 = undefined; | ||||||
|         var mtime: i128 = undefined; |         var mtime: i128 = undefined; | ||||||
|         var row: usize = undefined; |         var row: usize = undefined; | ||||||
|         var col: usize = undefined; |         var col: usize = undefined; | ||||||
|         if (!try cbor.matchValue(&iter, .{ |         if (!try cbor.matchValue(&iter, .{ | ||||||
|             tp.extract(&path), |             tp.extract(&path_), | ||||||
|             tp.extract(&mtime), |             tp.extract(&mtime), | ||||||
|             tp.extract(&row), |             tp.extract(&row), | ||||||
|             tp.extract(&col), |             tp.extract(&col), | ||||||
|  | @ -195,7 +196,8 @@ pub fn restore_state_v1(self: *Self, data: []const u8) !void { | ||||||
|             try cbor.skipValue(&iter); |             try cbor.skipValue(&iter); | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         tp.trace(tp.channel.debug, .{ "restore_state_v1", "file", path, mtime, row, col }); |         tp.trace(tp.channel.debug, .{ "restore_state_v1", "file", path_, mtime, row, col }); | ||||||
|  |         const path = project_manager.normalize_file_path_dot_prefix(path_); | ||||||
|         self.longest_file_path = @max(self.longest_file_path, path.len); |         self.longest_file_path = @max(self.longest_file_path, path.len); | ||||||
|         const stat = std.fs.cwd().statFile(path) catch |e| switch (e) { |         const stat = std.fs.cwd().statFile(path) catch |e| switch (e) { | ||||||
|             error.FileNotFound => continue, |             error.FileNotFound => continue, | ||||||
|  | @ -249,7 +251,7 @@ pub fn restore_state_v0(self: *Self, data: []const u8) error{ | ||||||
|     tp.trace(tp.channel.debug, .{"restore_state_v0"}); |     tp.trace(tp.channel.debug, .{"restore_state_v0"}); | ||||||
|     defer self.sort_files_by_mtime(); |     defer self.sort_files_by_mtime(); | ||||||
|     var name: []const u8 = undefined; |     var name: []const u8 = undefined; | ||||||
|     var path: []const u8 = undefined; |     var path_: []const u8 = undefined; | ||||||
|     var mtime: i128 = undefined; |     var mtime: i128 = undefined; | ||||||
|     var row: usize = undefined; |     var row: usize = undefined; | ||||||
|     var col: usize = undefined; |     var col: usize = undefined; | ||||||
|  | @ -257,7 +259,7 @@ pub fn restore_state_v0(self: *Self, data: []const u8) error{ | ||||||
|     _ = cbor.matchValue(&iter, tp.extract(&name)) catch {}; |     _ = cbor.matchValue(&iter, tp.extract(&name)) catch {}; | ||||||
|     tp.trace(tp.channel.debug, .{ "restore_state_v0", "name", name }); |     tp.trace(tp.channel.debug, .{ "restore_state_v0", "name", name }); | ||||||
|     while (cbor.matchValue(&iter, .{ |     while (cbor.matchValue(&iter, .{ | ||||||
|         tp.extract(&path), |         tp.extract(&path_), | ||||||
|         tp.extract(&mtime), |         tp.extract(&mtime), | ||||||
|         tp.extract(&row), |         tp.extract(&row), | ||||||
|         tp.extract(&col), |         tp.extract(&col), | ||||||
|  | @ -265,7 +267,8 @@ pub fn restore_state_v0(self: *Self, data: []const u8) error{ | ||||||
|         error.TooShort => return, |         error.TooShort => return, | ||||||
|         else => return e, |         else => return e, | ||||||
|     }) { |     }) { | ||||||
|         tp.trace(tp.channel.debug, .{ "restore_state_v0", "file", path, mtime, row, col }); |         tp.trace(tp.channel.debug, .{ "restore_state_v0", "file", path_, mtime, row, col }); | ||||||
|  |         const path = project_manager.normalize_file_path_dot_prefix(path_); | ||||||
|         self.longest_file_path = @max(self.longest_file_path, path.len); |         self.longest_file_path = @max(self.longest_file_path, path.len); | ||||||
|         const stat = std.fs.cwd().statFile(path) catch |e| switch (e) { |         const stat = std.fs.cwd().statFile(path) catch |e| switch (e) { | ||||||
|             error.FileNotFound => continue, |             error.FileNotFound => continue, | ||||||
|  |  | ||||||
|  | @ -825,10 +825,29 @@ fn request_path_files_async(a_: std.mem.Allocator, parent_: tp.pid_ref, project_ | ||||||
| 
 | 
 | ||||||
| pub fn normalize_file_path(file_path: []const u8) []const u8 { | pub fn normalize_file_path(file_path: []const u8) []const u8 { | ||||||
|     const project = tp.env.get().str("project"); |     const project = tp.env.get().str("project"); | ||||||
|     if (project.len == 0) return file_path; |     const file_path_ = if (project.len == 0) | ||||||
|     if (project.len >= file_path.len) return file_path; |         file_path | ||||||
|     if (std.mem.eql(u8, project, file_path[0..project.len]) and file_path[project.len] == std.fs.path.sep) |     else if (project.len >= file_path.len) | ||||||
|         return file_path[project.len + 1 ..]; |         file_path | ||||||
|  |     else if (std.mem.eql(u8, project, file_path[0..project.len]) and file_path[project.len] == std.fs.path.sep) | ||||||
|  |         file_path[project.len + 1 ..] | ||||||
|  |     else | ||||||
|  |         file_path; | ||||||
|  |     return normalize_file_path_dot_prefix(file_path_); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | pub fn normalize_file_path_dot_prefix(file_path: []const u8) []const u8 { | ||||||
|  |     if (file_path.len == 2 and file_path[0] == '.' and file_path[1] == std.fs.path.sep) | ||||||
|  |         return file_path; | ||||||
|  |     if (file_path.len >= 2 and file_path[0] == '.' and file_path[1] == std.fs.path.sep) { | ||||||
|  |         const file_path_ = file_path[2..]; | ||||||
|  |         return if (file_path_.len > 1 and file_path_[0] == std.fs.path.sep) | ||||||
|  |             normalize_file_path_dot_prefix(file_path_[1..]) | ||||||
|  |         else if (file_path_.len > 1) | ||||||
|  |             normalize_file_path_dot_prefix(file_path_) | ||||||
|  |         else | ||||||
|  |             file_path_; | ||||||
|  |     } | ||||||
|     return file_path; |     return file_path; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -2,6 +2,7 @@ const std = @import("std"); | ||||||
| pub const buffer = @import("tests_buffer.zig"); | pub const buffer = @import("tests_buffer.zig"); | ||||||
| pub const color = @import("tests_color.zig"); | pub const color = @import("tests_color.zig"); | ||||||
| pub const helix = @import("tests_helix.zig"); | pub const helix = @import("tests_helix.zig"); | ||||||
|  | pub const project_manager = @import("tests_project_manager.zig"); | ||||||
| 
 | 
 | ||||||
| test { | test { | ||||||
|     std.testing.refAllDecls(@This()); |     std.testing.refAllDecls(@This()); | ||||||
|  |  | ||||||
							
								
								
									
										19
									
								
								test/tests_project_manager.zig
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								test/tests_project_manager.zig
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,19 @@ | ||||||
|  | const std = @import("std"); | ||||||
|  | const pm = @import("project_manager"); | ||||||
|  | 
 | ||||||
|  | test "normalize_file_path_dot_prefix" { | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix("example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("/example.txt", pm.normalize_file_path_dot_prefix("/example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix("./example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix("././example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix(".//example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix(".//./example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("example.txt", pm.normalize_file_path_dot_prefix(".//.//example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("../example.txt", pm.normalize_file_path_dot_prefix("./../example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("../example.txt", pm.normalize_file_path_dot_prefix(".//../example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("../example.txt", pm.normalize_file_path_dot_prefix("././../example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("../example.txt", pm.normalize_file_path_dot_prefix("././/../example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("../example.txt", pm.normalize_file_path_dot_prefix(".//.//../example.txt")); | ||||||
|  |     try std.testing.expectEqualStrings("./", pm.normalize_file_path_dot_prefix("./")); | ||||||
|  |     try std.testing.expectEqualStrings(".", pm.normalize_file_path_dot_prefix(".")); | ||||||
|  | } | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue