# HG changeset patch # User Kim F. Storm # Date 1158793637 0 # Node ID 8a6d7bd59539a6aee534134f3b5d1cb13e1764d1 # Parent 66a5ba8082a997b883d4389fd10daa4308898aec (Fmemq): Refill doc string. (Fmemql): New defun, like memq but using eql. (syms_of_fns): Defsubr it. diff -r 66a5ba8082a9 -r 8a6d7bd59539 src/fns.c --- a/src/fns.c Wed Sep 20 20:46:33 2006 +0000 +++ b/src/fns.c Wed Sep 20 23:07:17 2006 +0000 @@ -1464,11 +1464,10 @@ } DEFUN ("memq", Fmemq, Smemq, 2, 2, 0, - doc: /* Return non-nil if ELT is an element of LIST. -Comparison done with `eq'. The value is actually the tail of LIST -whose car is ELT. */) +doc: /* Return non-nil if ELT is an element of LIST. Comparison done with `eq'. +The value is actually the tail of LIST whose car is ELT. */) (elt, list) - Lisp_Object elt, list; + register Lisp_Object elt, list; { while (1) { @@ -1491,6 +1490,30 @@ return list; } +DEFUN ("memql", Fmemql, Smemql, 2, 2, 0, +doc: /* Return non-nil if ELT is an element of LIST. Comparison done with `eql'. +The value is actually the tail of LIST whose car is ELT. */) + (elt, list) + register Lisp_Object elt; + Lisp_Object list; +{ + register Lisp_Object tail; + + if (!FLOATP (elt)) + return Fmemq (elt, list); + + for (tail = list; !NILP (tail); tail = XCDR (tail)) + { + register Lisp_Object tem; + CHECK_LIST_CONS (tail, list); + tem = XCAR (tail); + if (FLOATP (tem) && internal_equal (elt, tem, 0, 0)) + return tail; + QUIT; + } + return Qnil; +} + DEFUN ("assq", Fassq, Sassq, 2, 2, 0, doc: /* Return non-nil if KEY is `eq' to the car of an element of LIST. The value is actually the first element of LIST whose car is KEY. @@ -5833,6 +5856,7 @@ defsubr (&Selt); defsubr (&Smember); defsubr (&Smemq); + defsubr (&Smemql); defsubr (&Sassq); defsubr (&Sassoc); defsubr (&Srassq);