30 lines
718 B
Factor
30 lines
718 B
Factor
! Copyright (C) 2009 Slava Pestov.
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
USING: kernel sequences fry math.order splitting ;
|
|
IN: strings.tables
|
|
|
|
<PRIVATE
|
|
|
|
: map-last ( seq quot -- seq )
|
|
[ dup length <reversed> ] dip '[ 0 = @ ] 2map ; inline
|
|
|
|
: max-length ( seq -- n )
|
|
[ length ] [ max ] map-reduce ;
|
|
|
|
: format-row ( seq ? -- seq )
|
|
[
|
|
dup max-length
|
|
'[ _ "" pad-tail ] map
|
|
] unless ;
|
|
|
|
: format-column ( seq ? -- seq )
|
|
[
|
|
dup max-length
|
|
'[ _ CHAR: \s pad-tail ] map
|
|
] unless ;
|
|
|
|
PRIVATE>
|
|
|
|
: format-table ( table -- seq )
|
|
[ [ [ string-lines ] map ] dip format-row flip ] map-last concat
|
|
flip [ format-column ] map-last flip [ " " join ] map ; |