# HG changeset patch # User Dmitry Dzhus # Date 1251141166 0 # Node ID 81d782e3337d0fa82779a8b70a22cf129a2d5dde # Parent 305e338bced3e2ea3903d9490acc3e2d4361cf77 (gdb-mapcar*): Replacement for `mapcar*' from cl package. (gdb-table-add-row, gdb-table-string): Use `gdb-mapcar*'. diff -r 305e338bced3 -r 81d782e3337d lisp/ChangeLog --- a/lisp/ChangeLog Mon Aug 24 18:43:50 2009 +0000 +++ b/lisp/ChangeLog Mon Aug 24 19:12:46 2009 +0000 @@ -1,3 +1,9 @@ +2009-08-24 Dmitry Dzhus + + * progmodes/gdb-mi.el (gdb-mapcar*): Replacement for `mapcar*' + from cl package. + (gdb-table-add-row, gdb-table-string): Use `gdb-mapcar*'. + 2009-08-24 Jay Belanger * calc/calc-alg.el (math-trig-rewrite) diff -r 305e338bced3 -r 81d782e3337d lisp/progmodes/gdb-mi.el --- a/lisp/progmodes/gdb-mi.el Mon Aug 24 18:43:50 2009 +0000 +++ b/lisp/progmodes/gdb-mi.el Mon Aug 24 19:12:46 2009 +0000 @@ -2119,6 +2119,20 @@ (row-properties nil) (right-align nil)) +(defun gdb-mapcar* (function &rest seqs) + "Apply FUNCTION to each element of SEQS, and make a list of the results. +If there are several SEQS, FUNCTION is called with that many +arugments, and mapping stops as sson as the shortest list runs +out." + (let ((shortest (apply #'min (mapcar #'length seqs)))) + (mapcar (lambda (i) + (apply function + (mapcar + (lambda (seq) + (nth i seq)) + seqs))) + (number-sequence 0 (1- shortest))))) + (defun gdb-table-add-row (table row &optional properties) "Add ROW of string to TABLE and recalculate column sizes. @@ -2136,7 +2150,7 @@ (setf (gdb-table-row-properties table) (append row-properties (list properties))) (setf (gdb-table-column-sizes table) - (mapcar* (lambda (x s) + (gdb-mapcar* (lambda (x s) (let ((new-x (max (abs x) (string-width (or s ""))))) (if right-align new-x (- new-x)))) @@ -2152,12 +2166,12 @@ (res "")) (mapconcat 'identity - (mapcar* + (gdb-mapcar* (lambda (row properties) (apply 'propertize (mapconcat 'identity - (mapcar* (lambda (s x) (gdb-pad-string s x)) - row column-sizes) + (gdb-mapcar* (lambda (s x) (gdb-pad-string s x)) + row column-sizes) sep) properties)) (gdb-table-rows table)