mirror of
https://gittea.dev/nova/th.git
synced 2025-10-24 20:00:16 -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,15 +441,19 @@ 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 */
|
||||
(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)));
|
||||
|
||||
/*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)));
|
||||
|
||||
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';
|
||||
@@ -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