1
0
mirror of https://git.FreeBSD.org/ports.git synced 2024-11-14 23:46:10 +00:00
freebsd-ports/cad/spice/files/patch-ae
Chuck Robey 86b6c6a9c5 Fix floating point problem and flatten out multi-file patch.
PR:		10481
Submitted by:	Kouichi Hirabayashi <kh@mogami-wire.co.jp>
1999-03-08 18:40:17 +00:00

83 lines
2.0 KiB
Plaintext

diff -cr spice3f4/src/lib/cp/history.c src/lib/cp/history.c
*** spice3f4/src/lib/cp/history.c Thu Jun 17 17:32:40 1993
--- src/lib/cp/history.c Tue Nov 4 22:18:54 1997
***************
*** 11,16 ****
--- 11,24 ----
#include "cpdefs.h"
#include "suffix.h"
+ #ifdef HAS_GNUREADLINE
+
+ /* Added GNU Readline Support -- Andrew Veliath <veliaa@rpi.edu> */
+ #include <readline/readline.h>
+ #include <readline/history.h>
+
+ #endif /* HAS_GNUREADLINE */
+
static char *dohs();
static void freehist();
static wordlist *dohmod();
***************
*** 19,24 ****
--- 27,33 ----
static wordlist *hpattern();
static wordlist *hprefix();
+
struct histent *cp_lastone = NULL;
int cp_maxhistlength = 1000;
char cp_hat = '^';
***************
*** 345,352 ****
--- 354,363 ----
cp_lastone->hi_next = NULL;
cp_lastone->hi_event = event;
cp_lastone->hi_wlist = wl_copy(wlist);
+ #ifndef HAS_GNUREADLINE
freehist(histlength - cp_maxhistlength);
histlength++;
+ #endif
return;
}
***************
*** 483,492 ****
--- 494,529 ----
wl = wl->wl_next;
rev = true;
}
+ #ifdef HAS_GNUREADLINE
+ /* Added GNU Readline Support -- Andrew Veliath <veliaa@rpi.edu> */
+ {
+ HIST_ENTRY *he;
+ int i, N;
+
+ N = (wl == NULL) ? history_length : atoi(wl->wl_word);
+
+ if (N < 0) N = 0;
+ if (N > history_length) N = history_length;
+
+ if (rev)
+ for (i = history_length; i > 0 && N; --i, --N) {
+ he = history_get(i);
+ if (!he) return;
+ fprintf(cp_out, "%d\t%s\n", i, he->line);
+ }
+ else
+ for (i = history_length - N + 1; i <= history_length; ++i) {
+ he = history_get(i);
+ if (!he) return;
+ fprintf(cp_out, "%d\t%s\n", i, he->line);
+ }
+ }
+ #else
if (wl == NULL)
cp_hprint(cp_event - 1, cp_event - histlength, rev);
else
cp_hprint(cp_event - 1, cp_event - 1 - atoi(wl->wl_word), rev);
+ #endif /* ifelse HAS_GNUREADLINE */
return;
}