feat(project): add --no-persist to prevent new project persisting
				
					
				
			This commit is contained in:
		
							parent
							
								
									88ca1cd343
								
							
						
					
					
						commit
						910331868e
					
				
					 3 changed files with 9 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -20,6 +20,7 @@ open_time: i64,
 | 
			
		|||
language_servers: std.StringHashMap(LSP),
 | 
			
		||||
file_language_server: std.StringHashMap(LSP),
 | 
			
		||||
tasks: std.ArrayList(Task),
 | 
			
		||||
persistent: bool = false,
 | 
			
		||||
 | 
			
		||||
const Self = @This();
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -130,6 +131,7 @@ pub fn restore_state(self: *Self, data: []const u8) !void {
 | 
			
		|||
        error.InvalidType => return self.restore_state_v0(data),
 | 
			
		||||
        else => return tp.trace(tp.channel.debug, .{ "restore_state", "unknown format", data }),
 | 
			
		||||
    };
 | 
			
		||||
    self.persistent = true;
 | 
			
		||||
    return self.restore_state_v1(data);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -53,6 +53,7 @@ pub fn main() anyerror!void {
 | 
			
		|||
 | 
			
		||||
        pub const descriptions = .{
 | 
			
		||||
            .project = "Set project directory (default: cwd)",
 | 
			
		||||
            .no_persist = "Do not persist new projects",
 | 
			
		||||
            .frame_rate = "Set target frame rate (default: 60)",
 | 
			
		||||
            .debug_wait = "Wait for key press before starting UI",
 | 
			
		||||
            .debug_dump_on_error = "Dump stack traces on errors",
 | 
			
		||||
| 
						 | 
				
			
			@ -76,6 +77,7 @@ pub fn main() anyerror!void {
 | 
			
		|||
 | 
			
		||||
        pub const switches = .{
 | 
			
		||||
            .project = 'p',
 | 
			
		||||
            .no_persist = 'N',
 | 
			
		||||
            .frame_rate = 'f',
 | 
			
		||||
            .trace_level = 't',
 | 
			
		||||
            .language = 'l',
 | 
			
		||||
| 
						 | 
				
			
			@ -85,6 +87,7 @@ pub fn main() anyerror!void {
 | 
			
		|||
        };
 | 
			
		||||
 | 
			
		||||
        project: ?[]const u8,
 | 
			
		||||
        no_persist: bool,
 | 
			
		||||
        frame_rate: ?usize,
 | 
			
		||||
        debug_wait: bool,
 | 
			
		||||
        debug_dump_on_error: bool,
 | 
			
		||||
| 
						 | 
				
			
			@ -202,6 +205,7 @@ pub fn main() anyerror!void {
 | 
			
		|||
    log.set_std_log_pid(log_proc.ref());
 | 
			
		||||
    defer log.set_std_log_pid(null);
 | 
			
		||||
 | 
			
		||||
    env.set("no-persist", args.no_persist);
 | 
			
		||||
    env.set("restore-session", args.restore_session);
 | 
			
		||||
    env.set("no-alternate", args.no_alternate);
 | 
			
		||||
    env.set("show-input", args.show_input);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -423,6 +423,7 @@ const Process = struct {
 | 
			
		|||
    fn close(self: *Process, project_directory: []const u8) error{}!void {
 | 
			
		||||
        if (self.projects.fetchRemove(project_directory)) |kv| {
 | 
			
		||||
            self.allocator.free(kv.key);
 | 
			
		||||
            self.persist_project(kv.value) catch {};
 | 
			
		||||
            kv.value.deinit();
 | 
			
		||||
            self.allocator.destroy(kv.value);
 | 
			
		||||
            self.logger.print("closed: {s}", .{project_directory});
 | 
			
		||||
| 
						 | 
				
			
			@ -629,6 +630,8 @@ const Process = struct {
 | 
			
		|||
    }
 | 
			
		||||
 | 
			
		||||
    fn persist_project(self: *Process, project: *Project) !void {
 | 
			
		||||
        const no_persist = tp.env.get().is("no-persist");
 | 
			
		||||
        if (no_persist and !project.persistent) return;
 | 
			
		||||
        tp.trace(tp.channel.debug, .{ "persist_project", project.name });
 | 
			
		||||
        self.logger.print("saving: {s}", .{project.name});
 | 
			
		||||
        const file_name = try get_project_state_file_path(self.allocator, project);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue