mirror of
				https://gittea.dev/nova/th.git
				synced 2025-10-25 12:20:16 -04:00 
			
		
		
		
	various changes to functions modifying btm_buffer
This commit is contained in:
		| @@ -56,6 +56,8 @@ | |||||||
| #define YANK_CUT 2 | #define YANK_CUT 2 | ||||||
| #define YANK_COPY 4 | #define YANK_COPY 4 | ||||||
|  |  | ||||||
|  | #define BTM_WINDOW_HEIGHT_ON_STR_INTERACTION 5 | ||||||
|  |  | ||||||
| #ifndef STRUCT_GUARD | #ifndef STRUCT_GUARD | ||||||
| #define STRUCT_GUARD | #define STRUCT_GUARD | ||||||
| /* complex types are good actually */ | /* complex types are good actually */ | ||||||
|   | |||||||
							
								
								
									
										174
									
								
								interactions.c
									
									
									
									
									
								
							
							
						
						
									
										174
									
								
								interactions.c
									
									
									
									
									
								
							| @@ -48,6 +48,7 @@ yank yank_files = { 0 }; | |||||||
|  |  | ||||||
| int read_string(WINDOW *win, int y, int x, char *str); | int read_string(WINDOW *win, int y, int x, char *str); | ||||||
| extern void render_pass(); | extern void render_pass(); | ||||||
|  | void window_btm(WINDOW *win, char force_render); | ||||||
| extern int (*order_func)(); | extern int (*order_func)(); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -323,26 +324,25 @@ void jump_top(){ | |||||||
| void open_with(){ | void open_with(){ | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	char *btm_buffer_tmp = btm_buffer; | ||||||
|  | 	werase(win_b); | ||||||
|  | 	mvwin(win_b, terminal_height-6, 0); | ||||||
|  | 	wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
|  |  | ||||||
| 	btm_buffer = concat("open \"", mid_content[selected_file_current].file_name); | 	btm_buffer = concat("open \"", mid_content[selected_file_current].file_name); | ||||||
| 	btm_buffer = concat(btm_buffer, "\" with:"); | 	btm_buffer = concat(btm_buffer, "\" with:"); | ||||||
|  |  | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; | 	window_btm(win_b, 1); | ||||||
| 	werase(win_b); |  | ||||||
| 	mvwin(win_b, terminal_height-6, 0); |  | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ |  | ||||||
|  |  | ||||||
| 	render_pass(); |  | ||||||
| 	unsigned long local_height; |  | ||||||
| 	local_height = getmaxy(win_b); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/* TODO(2025-06-22T01:24:36) fix fixed buffer size */ | 	/* TODO(2025-06-22T01:24:36) fix fixed buffer size */ | ||||||
| 	char *str = malloc(255); | 	char *str = malloc(255); | ||||||
| 	memset(str, ' ', 255); | 	memset(str, ' ', 255); | ||||||
| 	int err = read_string(win_b, local_height - 1, 0 , str); | 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0 , str); | ||||||
|  |  | ||||||
| 	 | 	 | ||||||
| 	if (!err) { | 	if (err == 0) { | ||||||
| 		char *cmd = concat(str, " ./\""); | 		char *cmd = concat(str, " ./\""); | ||||||
| 		cmd = concat(cmd, mid_content[selected_file_current].file_name); | 		cmd = concat(cmd, mid_content[selected_file_current].file_name); | ||||||
| 		cmd = concat(cmd, "\""); | 		cmd = concat(cmd, "\""); | ||||||
| @@ -354,39 +354,34 @@ void open_with(){ | |||||||
| 		if (system(cmd) == -1) { | 		if (system(cmd) == -1) { | ||||||
| 			FAIL("open_with", "creating subcommand failed unhandled"); | 			FAIL("open_with", "creating subcommand failed unhandled"); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		free(btm_buffer); |  | ||||||
| 		btm_buffer = cmd; |  | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
|  |  | ||||||
|  | 	free(btm_buffer); | ||||||
|  | 	btm_buffer = btm_buffer_tmp; | ||||||
|  | 	pthread_mutex_unlock(&mutex_btm); | ||||||
|  |  | ||||||
| 	free(str); | 	free(str); | ||||||
| } | } | ||||||
|  |  | ||||||
| void rename_hovered(){ | void rename_hovered(){ | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
|  | 	char *btm_buffer_tmp = btm_buffer; | ||||||
|  | 	werase(win_b); | ||||||
|  | 	mvwin(win_b, terminal_height-6, 0); | ||||||
|  | 	wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
|  |  | ||||||
| 	btm_buffer = concat("rename \"", mid_content[selected_file_current].file_name); | 	btm_buffer = concat("rename \"", mid_content[selected_file_current].file_name); | ||||||
| 	btm_buffer = concat(btm_buffer, "\" to:"); | 	btm_buffer = concat(btm_buffer, "\" to:"); | ||||||
|  |  | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; | 	window_btm(win_b, 1); | ||||||
| 	werase(win_b); |  | ||||||
| 	mvwin(win_b, terminal_height-6, 0); |  | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ |  | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); |  | ||||||
| 	render_pass(); |  | ||||||
| 	pthread_mutex_lock(&mutex_btm); |  | ||||||
|  |  | ||||||
| 	unsigned long local_height; |  | ||||||
| 	local_height = getmaxy(win_b); |  | ||||||
|  |  | ||||||
| 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | ||||||
| 	char *str = malloc(255); | 	char *str = malloc(255); | ||||||
| 	memset(str, ' ', 255); | 	memset(str, ' ', 255); | ||||||
| 	int err = read_string(win_b, local_height - 1, 0, str); | 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||||
|  |  | ||||||
| 	 | 	 | ||||||
| 	if (!err) { | 	if (!err) { | ||||||
| @@ -400,17 +395,21 @@ void rename_hovered(){ | |||||||
| 		}; | 		}; | ||||||
| 		btm_buffer = cmd; | 		btm_buffer = cmd; | ||||||
| 	} | 	} | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	free(str); | ||||||
|  | 	free(btm_buffer); | ||||||
|  | 	btm_buffer = btm_buffer_tmp; | ||||||
|  |  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
|  |  | ||||||
|  | 	pthread_mutex_unlock(&mutex_btm); | ||||||
|  |  | ||||||
| 	free(str); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void delete(){ | void delete(){ | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
|  | 	char *btm_buffer_tmp = btm_buffer; | ||||||
|  |  | ||||||
| 	unsigned int i = 0; | 	unsigned int i = 0; | ||||||
| 	unsigned int hits = 0; | 	unsigned int hits = 0; | ||||||
| 	char *file_str = " "; | 	char *file_str = " "; | ||||||
| @@ -423,32 +422,46 @@ void delete(){ | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (hits) { |  | ||||||
| 		btm_buffer = concat("delete:", file_str); |  | ||||||
| 	} else { |  | ||||||
| 		btm_buffer = concat("delete: \"", mid_content[selected_file_current].file_name); |  | ||||||
| 		btm_buffer = concat(btm_buffer, "\""); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	btm_buffer = concat(btm_buffer, "?"); |  | ||||||
| 	btm_buffer = concat(btm_buffer, "\n\n"); |  | ||||||
| 	btm_buffer = concat(btm_buffer, "(y/N)"); |  | ||||||
|  |  | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; |  | ||||||
| 	werase(win_b); | 	werase(win_b); | ||||||
| 	mvwin(win_b, terminal_height-6, 0); | 	mvwin(win_b, terminal_height-6, 0); | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ | 	if (strlen(file_str) < (BTM_WINDOW_HEIGHT_ON_STR_INTERACTION-1) * (terminal_width/3)) { | ||||||
|  | 		wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
|  | 		btm_buffer = malloc(BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * (terminal_width/3)); | ||||||
|  | 		memset(btm_buffer, ' ', (BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * (terminal_width/3))); | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 		memcpy(btm_buffer, "delete: ",strlen("delete: ")); | ||||||
| 	render_pass(); | 		if (hits) { | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 			memcpy(btm_buffer + strlen("delete: "), file_str, strlen(file_str)); | ||||||
|  | 		} else { | ||||||
|  | 			btm_buffer[strlen("delete: ")] = '"'; | ||||||
|  | 			memcpy(btm_buffer + strlen("delete: ") + sizeof(char), mid_content[selected_file_current].file_name, strlen(mid_content[selected_file_current].file_name)-1); | ||||||
|  | 			btm_buffer[strlen("delete: ") + sizeof(char) + strlen(mid_content[selected_file_current].file_name)] = '"'; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		memcpy(btm_buffer + (BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * (terminal_width/3) - (terminal_width/3)) , "(y/N)", strlen("(y/N)")); | ||||||
|  | 		btm_buffer[BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * (terminal_width/3)] = '\0'; | ||||||
|  |  | ||||||
|  | 	} else { | ||||||
|  | 		wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width); /*since more data is present than can be represented using div3, we do the uncool thing)*/ | ||||||
|  | 		btm_buffer = malloc(BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width); | ||||||
|  | 		memset(btm_buffer, ' ', BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width); | ||||||
|  |  | ||||||
|  | 		memcpy(btm_buffer, "delete: ",strlen("delete: ")); | ||||||
|  | 		memcpy(btm_buffer + strlen("delete: "), file_str, (strlen(file_str) > ((BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width) - terminal_width) ? ((BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width) - terminal_width) : strlen(file_str))); | ||||||
|  |  | ||||||
|  | 		memcpy(btm_buffer + (BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width - terminal_width) , "(y/N)", strlen("(y/N)")); | ||||||
|  | 		btm_buffer[BTM_WINDOW_HEIGHT_ON_STR_INTERACTION * terminal_width] = '\0'; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	window_btm(win_b, 1); | ||||||
|  |  | ||||||
| 	timeout(-1); /* negative numbers block until enter is pressed */ | 	timeout(-1); /* negative numbers block until enter is pressed */ | ||||||
| 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | ||||||
| 	char ch = wgetch(win_b); | 	char ch = wgetch(win_b); | ||||||
| 	 | 	 | ||||||
| 	if (ch == 'y' || ch == 'Y') { | 	if (ch == 'y' || ch == 'Y') { | ||||||
| 		/* TODO(2025-06-30T02:27:06) IMPORTANT: this really fucks up when the file has a quotation mark in its name */ |  | ||||||
| 		if (hits) { | 		if (hits) { | ||||||
| 			for (i = 0; i < mid_file_count; i++) { | 			for (i = 0; i < mid_file_count; i++) { | ||||||
| 				if (mid_content[i].status & FILE_STATUS_SELECTED) { | 				if (mid_content[i].status & FILE_STATUS_SELECTED) { | ||||||
| @@ -456,54 +469,45 @@ void delete(){ | |||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 			free(btm_buffer); | 			free(btm_buffer); | ||||||
| 			btm_buffer = concat("deleted: ", file_str); |  | ||||||
| 		} else { | 		} else { | ||||||
| 			free(btm_buffer); | 			free(btm_buffer); | ||||||
| 			if (mid_content[selected_file_current].file_type & FILE_TYPE_DIR) { | 			if (mid_content[selected_file_current].file_type & FILE_TYPE_DIR) { | ||||||
| 				recursive_delete(mid_content[selected_file_current]); | 				recursive_delete(mid_content[selected_file_current]); | ||||||
| 			} | 			} | ||||||
| 			remove(mid_content[selected_file_current].file_name); | 			remove(mid_content[selected_file_current].file_name); | ||||||
| 			btm_buffer = concat("deleted: \"", mid_content[selected_file_current].file_name); |  | ||||||
| 			btm_buffer = concat(btm_buffer, "\""); |  | ||||||
|  |  | ||||||
| 		} | 		} | ||||||
| 		/*system(cmd);*/ | 	} | ||||||
|  | 	free(btm_buffer); | ||||||
| 	} else { | 	btm_buffer = btm_buffer_tmp; | ||||||
| 		free(btm_buffer); | 	if (hits) { | ||||||
| 		btm_buffer = "cancled deletion"; | 		free(file_str); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	timeout(10);  | 	timeout(10);  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
|  |  | ||||||
| 	if (hits) { |  | ||||||
| 		free(file_str); |  | ||||||
| 	} |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	pthread_mutex_unlock(&mutex_btm); | ||||||
| } | } | ||||||
|  |  | ||||||
| void makedir(){ | void makedir(){ | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	char *btm_buffer_tmp = btm_buffer; | ||||||
| 	werase(win_b); | 	werase(win_b); | ||||||
| 	mvwin(win_b, terminal_height-6, 0); | 	mvwin(win_b, terminal_height-6, 0); | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ | 	wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
| 	memset(btm_buffer, ' ', terminal_width); |  | ||||||
| 	memcpy(btm_buffer, "create dir: ", strlen("create dir: ")); |  | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; |  | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	btm_buffer = "create dir: "; | ||||||
| 	render_pass(); |  | ||||||
| 	pthread_mutex_lock(&mutex_btm); |  | ||||||
|  |  | ||||||
| 	unsigned long local_height; | 	window_btm(win_b, 1); | ||||||
| 	local_height = getmaxy(win_b); |  | ||||||
|  |  | ||||||
| 	/* TODO(2025-07-03T01:19:55) fix fixed buffer size */ | 	/* TODO(2025-07-03T01:19:55) fix fixed buffer size */ | ||||||
| 	char *str = malloc(255); | 	char *str = malloc(255); | ||||||
| 	memset(str, ' ', 255); | 	memset(str, ' ', 255); | ||||||
| 	int err = read_string(win_b, local_height - 1, 0, str); | 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||||
|  |  | ||||||
| 	if (!err) { | 	if (!err) { | ||||||
| 		btm_buffer = concat(btm_buffer, str); | 		btm_buffer = concat(btm_buffer, str); | ||||||
| 		mode_t mask = umask(0); | 		mode_t mask = umask(0); | ||||||
| @@ -511,29 +515,29 @@ void makedir(){ | |||||||
| 		umask(mask); | 		umask(mask); | ||||||
| 	} | 	} | ||||||
| 	free(str); | 	free(str); | ||||||
|  | 	free(btm_buffer); | ||||||
|  | 	btm_buffer = btm_buffer_tmp; | ||||||
|  |  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	pthread_mutex_unlock(&mutex_btm); | ||||||
| } | } | ||||||
| void makefile(){ | void makefile(){ | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
| 	memcpy(btm_buffer, "create file: ", strlen("create file: ")); | 	char *btm_buffer_tmp = btm_buffer; | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; |  | ||||||
| 	werase(win_b); | 	werase(win_b); | ||||||
| 	mvwin(win_b, terminal_height-6, 0); | 	mvwin(win_b, terminal_height-6, 0); | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ | 	wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	btm_buffer = "create file: "; | ||||||
| 	render_pass(); |  | ||||||
| 	pthread_mutex_lock(&mutex_btm); |  | ||||||
|  |  | ||||||
| 	unsigned long local_height; | 	window_btm(win_b, 1); | ||||||
| 	local_height = getmaxy(win_b); |  | ||||||
|  |  | ||||||
| 	/* TODO(2025-07-03T01:19:49) fix fixed buffer size */ | 	/* TODO(2025-07-03T01:19:49) fix fixed buffer size */ | ||||||
| 	char *str = malloc(255); | 	char *str = malloc(255); | ||||||
| 	memset(str, ' ', 255); | 	memset(str, ' ', 255); | ||||||
| 	int err = read_string(win_b, local_height - 1, 0, str); | 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||||
|  |  | ||||||
| 	if (!err) { | 	if (!err) { | ||||||
| 		btm_buffer = concat(btm_buffer, str); | 		btm_buffer = concat(btm_buffer, str); | ||||||
| 		FILE *fp; | 		FILE *fp; | ||||||
| @@ -541,8 +545,11 @@ void makefile(){ | |||||||
| 		fclose(fp); | 		fclose(fp); | ||||||
| 	} | 	} | ||||||
| 	free(str); | 	free(str); | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	free(btm_buffer); | ||||||
|  | 	btm_buffer = btm_buffer_tmp; | ||||||
|  |  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
|  | 	pthread_mutex_unlock(&mutex_btm); | ||||||
| } | } | ||||||
|  |  | ||||||
| void update(){ | void update(){ | ||||||
| @@ -640,6 +647,7 @@ void cmd_on_selected(unsigned long passes, int index){ | |||||||
| 	(void)passes; | 	(void)passes; | ||||||
| 	pthread_mutex_lock(&mutex_btm); | 	pthread_mutex_lock(&mutex_btm); | ||||||
|  |  | ||||||
|  | 	char *btm_buffer_tmp = btm_buffer; | ||||||
| 	unsigned int i = 0; | 	unsigned int i = 0; | ||||||
| 	unsigned int hits = 0; | 	unsigned int hits = 0; | ||||||
| 	char *file_str = " "; | 	char *file_str = " "; | ||||||
| @@ -664,15 +672,11 @@ void cmd_on_selected(unsigned long passes, int index){ | |||||||
| 	btm_buffer = concat(btm_buffer, "\n\n"); | 	btm_buffer = concat(btm_buffer, "\n\n"); | ||||||
| 	btm_buffer = concat(btm_buffer, "(y/N)"); | 	btm_buffer = concat(btm_buffer, "(y/N)"); | ||||||
|  |  | ||||||
| 	status |= STATUS_UPDATE_SCREEN_0; |  | ||||||
| 	werase(win_b); | 	werase(win_b); | ||||||
| 	mvwin(win_b, terminal_height-6, 0); | 	mvwin(win_b, terminal_height-6, 0); | ||||||
| 	wresize(win_b, 5, terminal_width/3); /*the div3 just looks cool*/ | 	wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width/3); /*the div3 just looks cool*/ | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); |  | ||||||
| 	render_pass(); |  | ||||||
| 	pthread_mutex_lock(&mutex_btm); |  | ||||||
|  |  | ||||||
|  | 	window_btm(win_b, 1); | ||||||
|  |  | ||||||
| 	timeout(-1); /* negative numbers block until enter is pressed */ | 	timeout(-1); /* negative numbers block until enter is pressed */ | ||||||
| 	/* TODO(2025-07-06T07:22:49) fix fixed buffer size */ | 	/* TODO(2025-07-06T07:22:49) fix fixed buffer size */ | ||||||
| @@ -715,6 +719,8 @@ void cmd_on_selected(unsigned long passes, int index){ | |||||||
| 		free(btm_buffer); | 		free(btm_buffer); | ||||||
| 		memcpy(btm_buffer, "cancled deletion", strlen("cancled deletion")); | 		memcpy(btm_buffer, "cancled deletion", strlen("cancled deletion")); | ||||||
| 	} | 	} | ||||||
|  | 	free(btm_buffer); | ||||||
|  | 	btm_buffer = btm_buffer_tmp; | ||||||
|  |  | ||||||
| 	timeout(10);  | 	timeout(10);  | ||||||
| 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | 	status |= (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY | STATUS_UPDATE_SCREEN_RELOAD_FULL); | ||||||
| @@ -844,9 +850,7 @@ void search(){ | |||||||
| 	local_height = getmaxy(win_b); | 	local_height = getmaxy(win_b); | ||||||
| 	memset(search_buffer, '\0', 255); | 	memset(search_buffer, '\0', 255); | ||||||
|  |  | ||||||
| 	pthread_mutex_unlock(&mutex_btm); | 	window_btm(win_b, 1); | ||||||
| 	render_pass(); |  | ||||||
| 	pthread_mutex_lock(&mutex_btm); |  | ||||||
|  |  | ||||||
| 	curs_set(1); | 	curs_set(1); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								main.c
									
									
									
									
									
								
							| @@ -145,11 +145,6 @@ void render_pass(){ | |||||||
|  |  | ||||||
| 		/*TODO: check if deallocation of window and reallocation is faster than this or not */ | 		/*TODO: check if deallocation of window and reallocation is faster than this or not */ | ||||||
|  |  | ||||||
| 		wclear(win_t); |  | ||||||
| 		wclear(win_b); |  | ||||||
| 		wclear(win_l); |  | ||||||
| 		wclear(win_m); |  | ||||||
| 		wclear(win_r); |  | ||||||
|  |  | ||||||
| 		wresize(win_t, 1, terminal_width); | 		wresize(win_t, 1, terminal_width); | ||||||
| 		wresize(win_l, terminal_height-2, terminal_width/8); | 		wresize(win_l, terminal_height-2, terminal_width/8); | ||||||
| @@ -174,7 +169,7 @@ void render_pass(){ | |||||||
| 		window_lft(win_l); | 		window_lft(win_l); | ||||||
| 		window_mid(win_m); | 		window_mid(win_m); | ||||||
| 		window_rgt(win_r); | 		window_rgt(win_r); | ||||||
| 		window_btm(win_b); | 		window_btm(win_b, 0); | ||||||
| 		wrefresh(win_t); | 		wrefresh(win_t); | ||||||
| 		wrefresh(win_l); | 		wrefresh(win_l); | ||||||
| 		wrefresh(win_m); | 		wrefresh(win_m); | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								window.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								window.c
									
									
									
									
									
								
							| @@ -48,7 +48,7 @@ void window_top(WINDOW *win){ | |||||||
| 		status |= STATUS_UPDATE_SCREEN_0; | 		status |= STATUS_UPDATE_SCREEN_0; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| void window_btm(WINDOW *win){ | void window_btm(WINDOW *win, char force_render){ | ||||||
| 	werase(win); | 	werase(win); | ||||||
|  |  | ||||||
| 	if (pthread_mutex_trylock(&mutex_btm) == 0) { | 	if (pthread_mutex_trylock(&mutex_btm) == 0) { | ||||||
| @@ -58,6 +58,10 @@ void window_btm(WINDOW *win){ | |||||||
| 		pthread_mutex_unlock(&mutex_btm); | 		pthread_mutex_unlock(&mutex_btm); | ||||||
| 		/*the printing of the input char is done in user_interactions*/ | 		/*the printing of the input char is done in user_interactions*/ | ||||||
| 		/*the printing of all possible inputs are done in user_interactions */ | 		/*the printing of all possible inputs are done in user_interactions */ | ||||||
|  | 	} else if (force_render) { | ||||||
|  | 		/*force_render is used in stuff like open_with, search, and other functions that take over win_b,  | ||||||
|  | 		 * while needing to avoid possible conflicts like thread_btm itself*/ | ||||||
|  | 		mvwprintw(win, 0, 0, "%s", btm_buffer); | ||||||
| 	} else { | 	} else { | ||||||
| 		mvwaddstr(win, 0, terminal_width/2, "LOADING");  | 		mvwaddstr(win, 0, terminal_width/2, "LOADING");  | ||||||
| 		status |= STATUS_UPDATE_SCREEN_0; | 		status |= STATUS_UPDATE_SCREEN_0; | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								window.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								window.h
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| #include "window.c" | #include "window.c" | ||||||
|  |  | ||||||
| void window_top(WINDOW *win); | void window_top(WINDOW *win); | ||||||
| void window_btm(WINDOW *win); | void window_btm(WINDOW *win, char force_render); | ||||||
| void window_lft(WINDOW *win); | void window_lft(WINDOW *win); | ||||||
| void window_mid(WINDOW *win); | void window_mid(WINDOW *win); | ||||||
| void window_rgt(WINDOW *win); | void window_rgt(WINDOW *win); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 nova
					nova