2010-01-14 10:10:13 -05:00
|
|
|
! Copyright (C) 2009, 2010 Slava Pestov.
|
2009-01-26 03:21:28 -05:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2012-07-13 21:42:34 -04:00
|
|
|
USING: kernel sequences fry math.order math.ranges splitting ;
|
2009-01-26 03:21:28 -05:00
|
|
|
IN: strings.tables
|
|
|
|
|
|
|
|
<PRIVATE
|
|
|
|
|
2009-04-30 21:03:52 -04:00
|
|
|
: max-length ( seq -- n )
|
2012-07-13 21:42:34 -04:00
|
|
|
[ length ] [ max ] map-reduce ; inline
|
2009-04-30 21:03:52 -04:00
|
|
|
|
2010-02-02 05:48:30 -05:00
|
|
|
: format-row ( seq -- seq )
|
2012-07-13 21:42:34 -04:00
|
|
|
dup max-length '[ _ "" pad-tail ] map! ;
|
2009-04-30 21:03:52 -04:00
|
|
|
|
2012-07-13 21:42:34 -04:00
|
|
|
: format-column ( seq -- seq )
|
|
|
|
dup max-length '[ _ CHAR: \s pad-tail ] map! ;
|
2009-01-26 03:21:28 -05:00
|
|
|
|
|
|
|
PRIVATE>
|
|
|
|
|
|
|
|
: format-table ( table -- seq )
|
2012-07-14 01:11:58 -04:00
|
|
|
[ [ string-lines ] map format-row flip ] map concat flip
|
|
|
|
[ { } ] [
|
|
|
|
[ but-last-slice [ format-column ] map! drop ] keep
|
|
|
|
flip [ " " join ] map!
|
|
|
|
] if-empty ;
|