From: Andrea Corallo Date: Wed, 2 Dec 2020 21:45:00 +0000 (+0100) Subject: * lisp/emacs-lisp/comp-cstr.el (comp-cstr-union-no-range): Cosmetic. X-Git-Tag: emacs-28.0.90~2727^2~288 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=1fb249f6db1ae87ee3ddd221ab9c8d152951efe7;p=emacs.git * lisp/emacs-lisp/comp-cstr.el (comp-cstr-union-no-range): Cosmetic. --- diff --git a/lisp/emacs-lisp/comp-cstr.el b/lisp/emacs-lisp/comp-cstr.el index dcf835bb7b1..6397bccdae5 100644 --- a/lisp/emacs-lisp/comp-cstr.el +++ b/lisp/emacs-lisp/comp-cstr.el @@ -256,26 +256,26 @@ Integer values are handled in the `range' slot.") (defun comp-cstr-union-no-range (dst &rest srcs) "As `comp-cstr-union' but escluding the irange component." - (let ((values (mapcar #'comp-cstr-valset srcs))) - - ;; Type propagation. - (setf (comp-cstr-typeset dst) - (apply #'comp-union-typesets (mapcar #'comp-cstr-typeset srcs))) - - ;; Value propagation. - (setf (comp-cstr-valset dst) - (cl-loop - ;; TODO sort. - for v in (cl-remove-duplicates (apply #'append values) - :test #'equal) - ;; We propagate only values those types are not already - ;; into typeset. - when (cl-notany (lambda (x) - (comp-subtype-p (type-of v) x)) - (comp-cstr-typeset dst)) - collect v)) - - dst)) + + ;; Type propagation. + (setf (comp-cstr-typeset dst) + (apply #'comp-union-typesets (mapcar #'comp-cstr-typeset srcs))) + + ;; Value propagation. + (setf (comp-cstr-valset dst) + (cl-loop + with values = (mapcar #'comp-cstr-valset srcs) + ;; TODO sort. + for v in (cl-remove-duplicates (apply #'append values) + :test #'equal) + ;; We propagate only values those types are not already + ;; into typeset. + when (cl-notany (lambda (x) + (comp-subtype-p (type-of v) x)) + (comp-cstr-typeset dst)) + collect v)) + + dst) (defun comp-cstr-union (dst &rest srcs) "Combine SRCS by union set operation setting the result in DST.