mirror of
				https://gittea.dev/nova/th.git
				synced 2025-10-25 04:10:15 -04:00 
			
		
		
		
	'refactoring'
This commit is contained in:
		| @@ -57,6 +57,7 @@ | ||||
| #define YANK_COPY 4 | ||||
|  | ||||
| #define BTM_WINDOW_HEIGHT_ON_STR_INTERACTION 5 | ||||
| #define INPUT_BUFFER_SIZE 255 | ||||
|  | ||||
| #ifndef STRUCT_GUARD | ||||
| #define STRUCT_GUARD | ||||
|   | ||||
| @@ -40,15 +40,14 @@ extern char *input; | ||||
|  | ||||
| extern time_t *seed; | ||||
|  | ||||
| char search_buffer[255]; | ||||
| char search_buffer[INPUT_BUFFER_SIZE]; | ||||
| unsigned int timeout_time = 0; | ||||
| unsigned int input_pass; | ||||
| unsigned long parsed_input_number; | ||||
| yank yank_files = { 0 }; | ||||
|  | ||||
| int read_string(WINDOW *win, int y, int x, char *str); | ||||
| extern void render_pass(); | ||||
| void window_btm(WINDOW *win, char force_render); | ||||
| extern void window_btm(WINDOW *win, char force_render); | ||||
| extern int (*order_func)(); | ||||
|  | ||||
|  | ||||
| @@ -78,7 +77,7 @@ void user_interactions() { | ||||
| 		if (ch == 27) { /* esc key */ | ||||
| 			memset(input, ' ', terminal_width); | ||||
| 			mvaddstr(terminal_height-1, (terminal_width/3)*2, input); | ||||
| 			memset(input, 0, 255); | ||||
| 			memset(input, 0, INPUT_BUFFER_SIZE); | ||||
| 			input_pass = 0; | ||||
| 			timeout(100); /* blocking timeout of getch() */ | ||||
| 		} | ||||
| @@ -126,7 +125,7 @@ void user_interactions() { | ||||
| 			attroff(A_UNDERLINE); | ||||
| 			status &= ~STATUS_INPUT_MATCH; | ||||
| 		} else if (number_length != strlen(input)) { | ||||
| 			memset(input, 0, 255); | ||||
| 			memset(input, 0, INPUT_BUFFER_SIZE); | ||||
| 			input_pass = 0; | ||||
| 			binding_pass = 0; | ||||
| 			number_length = 0; | ||||
| @@ -336,9 +335,9 @@ void open_with(){ | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
|  | ||||
| 	/* TODO(2025-06-22T01:24:36) fix fixed buffer size */ | ||||
| 	char *str = malloc(255); | ||||
| 	memset(str, ' ', 255); | ||||
| 	char *str = malloc(INPUT_BUFFER_SIZE); | ||||
| 	memset(str, ' ', INPUT_BUFFER_SIZE); | ||||
| 	str[INPUT_BUFFER_SIZE-1] = '\0'; | ||||
| 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0 , str); | ||||
|  | ||||
| 	 | ||||
| @@ -378,9 +377,9 @@ void rename_hovered(){ | ||||
|  | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
| 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | ||||
| 	char *str = malloc(255); | ||||
| 	memset(str, ' ', 255); | ||||
| 	char *str = malloc(INPUT_BUFFER_SIZE); | ||||
| 	memset(str, ' ', INPUT_BUFFER_SIZE); | ||||
| 	str[INPUT_BUFFER_SIZE-1] = '\0'; | ||||
| 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||
|  | ||||
| 	 | ||||
| @@ -442,12 +441,16 @@ void delete(){ | ||||
| 		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)*/ | ||||
| 		/*since more data is present than can be represented using div3, we do the uncool thing*/ | ||||
| 		wresize(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION, terminal_width);  | ||||
| 		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, /* this horrendous check tries to copy everything until the last line, while keeping said last line unwritten */ | ||||
|  | ||||
| 		/*this horrendous check tries to copy everything until the last line, while keeping said last line unwritten*/ | ||||
| 		/*lets hope im never gonna need to format something like this ever again*/ | ||||
| 		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))); | ||||
| @@ -461,7 +464,6 @@ void delete(){ | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
| 	timeout(-1); /* negative numbers block until enter is pressed */ | ||||
| 	/* TODO(2025-06-22T01:24:30) fix fixed buffer size */ | ||||
| 	char ch = wgetch(win_b); | ||||
| 	 | ||||
| 	if (ch == 'y' || ch == 'Y') { | ||||
| @@ -506,9 +508,9 @@ void makedir(){ | ||||
|  | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
| 	/* TODO(2025-07-03T01:19:55) fix fixed buffer size */ | ||||
| 	char *str = malloc(255); | ||||
| 	memset(str, ' ', 255); | ||||
| 	char *str = malloc(INPUT_BUFFER_SIZE); | ||||
| 	memset(str, ' ', INPUT_BUFFER_SIZE); | ||||
| 	str[INPUT_BUFFER_SIZE-1] = '\0'; | ||||
| 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||
|  | ||||
| 	if (!err) { | ||||
| @@ -536,9 +538,9 @@ void makefile(){ | ||||
|  | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
| 	/* TODO(2025-07-03T01:19:49) fix fixed buffer size */ | ||||
| 	char *str = malloc(255); | ||||
| 	memset(str, ' ', 255); | ||||
| 	char *str = malloc(INPUT_BUFFER_SIZE); | ||||
| 	memset(str, ' ', INPUT_BUFFER_SIZE); | ||||
| 	str[INPUT_BUFFER_SIZE-1] = '\0'; | ||||
| 	int err = read_string(win_b, BTM_WINDOW_HEIGHT_ON_STR_INTERACTION - 1, 0, str); | ||||
|  | ||||
| 	if (!err) { | ||||
| @@ -815,11 +817,11 @@ void paste(){ | ||||
| 		cmd = concat(cmd, " ./"); | ||||
| 		cmd = concat(cmd, *yank_files.list); | ||||
| 		cmd = concat(cmd, " 2>&1"); | ||||
| 		char *line = malloc(255); | ||||
| 		char *line = malloc(INPUT_BUFFER_SIZE); | ||||
| 		FILE *cmd_open; | ||||
| 		while (1) { | ||||
| 			cmd_open = popen(cmd, "r"); | ||||
| 			if (fgets(line, 255, cmd_open) == 0) { | ||||
| 			if (fgets(line, INPUT_BUFFER_SIZE, cmd_open) == 0) { | ||||
| 				break; | ||||
| 			} | ||||
| 			if (strstr(line, "are the same file")) { | ||||
| @@ -851,7 +853,7 @@ void search(){ | ||||
|  | ||||
| 	unsigned long local_height; | ||||
| 	local_height = getmaxy(win_b); | ||||
| 	memset(search_buffer, '\0', 255); | ||||
| 	memset(search_buffer, '\0', INPUT_BUFFER_SIZE); | ||||
|  | ||||
| 	window_btm(win_b, 1); | ||||
|  | ||||
| @@ -941,9 +943,9 @@ void search_previous(){ | ||||
| 	} | ||||
| } | ||||
| void jmp_file_index(){ | ||||
| 	char *index = malloc(255); | ||||
| 	memset(index, ' ', 255); | ||||
| 	index[254] = '\0'; | ||||
| 	char *index = malloc(INPUT_BUFFER_SIZE); | ||||
| 	memset(index, ' ', INPUT_BUFFER_SIZE); | ||||
| 	index[INPUT_BUFFER_SIZE-1] = '\0'; | ||||
| 	unsigned long local_height; | ||||
| 	local_height = getmaxy(win_b); | ||||
| 	read_string(win_b, local_height - 1, 0, index); | ||||
|   | ||||
							
								
								
									
										4
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								main.c
									
									
									
									
									
								
							| @@ -187,8 +187,8 @@ void init() { | ||||
| 	curs_set(0); | ||||
|  | ||||
| 	/*file_modifiers = (FILE_MODIFIERS_HIDDEN_FILES | FILE_MODIFIERS_SORT_BITMASK);*/ | ||||
| 	input = malloc(sizeof(char)*255); /* size of input buffer, out of bounds access will not be accounted for */ | ||||
| 	memset(input, 0, 255); | ||||
| 	input = malloc(INPUT_BUFFER_SIZE); /* size of input buffer, out of bounds access will not be accounted for */ | ||||
| 	memset(input, 0, INPUT_BUFFER_SIZE); | ||||
| 	status = (STATUS_RUN_BACKEND | STATUS_UPDATE_SCREEN_MASK | STATUS_RELOAD_DIRECTORY);  | ||||
| 	if (getuid() == 0) { | ||||
| 		status |= STATUS_USER_ROOT; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 nova
					nova