From 86840809690d05eac124c0ebdbb8f85eff9f711d Mon Sep 17 00:00:00 2001 From: Kenichi Handa Date: Tue, 6 Jun 2006 03:51:12 +0000 Subject: [PATCH] (assoc_no_quit): New function. --- src/fns.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/fns.c b/src/fns.c index 2d4c49fbaa2..545b4d7b0ea 100644 --- a/src/fns.c +++ b/src/fns.c @@ -1524,6 +1524,22 @@ The value is actually the first element of LIST whose car equals KEY. */) return result; } +/* Like Fassoc but never report an error and do not allow quits. + Use only on lists known never to be circular. */ + +Lisp_Object +assoc_no_quit (key, list) + Lisp_Object key, list; +{ + while (CONSP (list) + && (!CONSP (XCAR (list)) + || (!EQ (XCAR (XCAR (list)), key) + && NILP (Fequal (XCAR (XCAR (list)), key))))) + list = XCDR (list); + + return CONSP (list) ? XCAR (list) : Qnil; +} + DEFUN ("rassq", Frassq, Srassq, 2, 2, 0, doc: /* Return non-nil if KEY is `eq' to the cdr of an element of LIST. The value is actually the first element of LIST whose cdr is KEY. */) -- 2.39.5