diff options
Diffstat (limited to 'package')
| -rw-r--r-- | package/busybox/patches/903-lineedit.patch | 145 | 
1 files changed, 0 insertions, 145 deletions
| diff --git a/package/busybox/patches/903-lineedit.patch b/package/busybox/patches/903-lineedit.patch deleted file mode 100644 index aa6e13b1e..000000000 --- a/package/busybox/patches/903-lineedit.patch +++ /dev/null @@ -1,145 +0,0 @@ ---- a/libbb/lineedit.c -+++ b/libbb/lineedit.c -@@ -953,24 +953,33 @@ -  - #if MAX_HISTORY > 0 -  -+static void save_command_ps_at_cur_history(void) -+{ -+	if (command_ps[0] != '\0') { -+		int cur = state->cur_history; -+		free(state->history[cur]); -+		state->history[cur] = xstrdup(command_ps); -+	} -+} -+ - /* state->flags is already checked to be nonzero */ --static void get_previous_history(void) -+static int get_previous_history(void) - { --	if (command_ps[0] != '\0' || state->history[state->cur_history] == NULL) { --		free(state->history[state->cur_history]); --		state->history[state->cur_history] = xstrdup(command_ps); -+	if ((state->flags & DO_HISTORY) && state->cur_history) { -+		save_command_ps_at_cur_history(); -+		state->cur_history--; -+		return 1; - 	} --	state->cur_history--; -+	beep(); -+	return 0; - } -  - static int get_next_history(void) - { - 	if (state->flags & DO_HISTORY) { --		int ch = state->cur_history; --		if (ch < state->cnt_history) { --			get_previous_history(); /* save the current history line */ --			state->cur_history = ch + 1; --			return state->cur_history; -+		if (state->cur_history < state->cnt_history) { -+			save_command_ps_at_cur_history(); /* save the current history line */ -+			return ++state->cur_history; - 		} - 	} - 	beep(); -@@ -992,6 +1001,7 @@ - 		for (hi = state->cnt_history; hi > 0;) { - 			hi--; - 			free(state->history[hi]); -+			state->history[hi] = NULL; - 		} -  - 		for (hi = 0; hi < MAX_HISTORY;) { -@@ -1003,7 +1013,7 @@ - 			l = strlen(hl); - 			if (l >= MAX_LINELEN) - 				hl[MAX_LINELEN-1] = '\0'; --			if (l == 0 || hl[0] == ' ') { -+			if (l == 0) { - 				free(hl); - 				continue; - 			} -@@ -1040,19 +1050,27 @@ -  - 	if (!(state->flags & DO_HISTORY)) - 		return; -- -+	if (str[0] == '\0') -+		return; - 	i = state->cnt_history; --	free(state->history[MAX_HISTORY]); --	state->history[MAX_HISTORY] = NULL; --	/* After max history, remove the oldest command */ -+	/* Don't save dupes */ -+	if (i && strcmp(state->history[i-1], str) == 0) -+		return; -+ -+	free(state->history[MAX_HISTORY]); /* redundant, paranoia */ -+	state->history[MAX_HISTORY] = NULL; /* redundant, paranoia */ -+ -+	/* If history[] is full, remove the oldest command */ -+	/* we need to keep history[MAX_HISTORY] empty, hence >=, not > */ - 	if (i >= MAX_HISTORY) { - 		free(state->history[0]); - 		for (i = 0; i < MAX_HISTORY-1; i++) - 			state->history[i] = state->history[i+1]; -+		/* i == MAX_HISTORY-1 */ - 	} --// Maybe "if (!i || strcmp(history[i-1], command) != 0) ..." --// (i.e. do not save dups?) -+	/* i <= MAX_HISTORY-1 */ - 	state->history[i++] = xstrdup(str); -+	/* i <= MAX_HISTORY */ - 	state->cur_history = i; - 	state->cnt_history = i; - #if ENABLE_FEATURE_EDITING_SAVEHISTORY -@@ -1429,6 +1447,13 @@ - 		} - 	} - #endif -+ -+#if 0 -+	for (ic = 0; ic <= MAX_HISTORY; ic++) -+		bb_error_msg("history[%d]:'%s'", ic, state->history[ic]); -+	bb_error_msg("cur_history:%d cnt_history:%d", state->cur_history, state->cnt_history); -+#endif -+ - 	/* Print out the command prompt */ - 	parse_and_put_prompt(prompt); -  -@@ -1537,11 +1562,8 @@ - 		vi_case(CTRL('P')|vbit:) - 		vi_case('k'|vbit:) - 			/* Control-p -- Get previous command from history */ --			if ((state->flags & DO_HISTORY) && state->cur_history > 0) { --				get_previous_history(); -+			if (get_previous_history()) - 				goto rewrite_line; --			} --			beep(); - 			break; - #endif -  -@@ -1730,10 +1752,8 @@ - #if MAX_HISTORY > 0 - 			case 'A': - 				/* Up Arrow -- Get previous command from history */ --				if ((state->flags & DO_HISTORY) && state->cur_history > 0) { --					get_previous_history(); -+				if (get_previous_history()) - 					goto rewrite_line; --				} - 				beep(); - 				break; - 			case 'B': -@@ -1743,7 +1763,7 @@ -  rewrite_line: - 				/* Rewrite the line with the selected history item */ - 				/* change command */ --				command_len = strlen(strcpy(command, state->history[state->cur_history])); -+				command_len = strlen(strcpy(command, state->history[state->cur_history] ? : "")); - 				/* redraw and go to eol (bol, in vi */ - 				redraw(cmdedit_y, (state->flags & VI_MODE) ? 9999 : 0); - 				break; | 
