From 4d4396590bd0519e9ade2f4866c44fab274aaa15 Mon Sep 17 00:00:00 2001 From: Arun Isaac Date: Mon, 13 Dec 2021 15:38:50 +0530 Subject: Abstract out table to graphviz node conversion. * dump.scm (dumped-table?, table-label, table->graphviz-node): New functions. (dump-schema): Use table->graphviz-node. --- dump.scm | 66 +++++++++++++++++++++++++++++++++++++--------------------------- 1 file changed, 38 insertions(+), 28 deletions(-) diff --git a/dump.scm b/dump.scm index f8b3513..f5e40ce 100755 --- a/dump.scm +++ b/dump.scm @@ -625,38 +625,48 @@ metric." serialized string." (string-append "<" (sxml->xml-string tree) ">")) +(define (dumped-table? table) + "Return non-#f if TABLE has been dumped. Else, return #f." + (any (match-lambda + ((dumped-table . _) + (string=? (symbol->string dumped-table) + (table-name table))) + (x (error "Malformed entry in %dumped:" x))) + %dumped)) + +(define (table-label table) + "Return HTML string label for TABLE." + (sxml->graphviz-html + `(table (@ (border 0)) + (tr (td (@ (border 1) + (bgcolor ,(human-units-color (table-size table)))) + ,(format #f "~a (~a)" + (table-name table) + (human-units (table-size table))))) + ,@(map (lambda (column) + `(tr (td (@ ,@(if (member (cons (string->symbol (table-name table)) + (string->symbol (column-name column))) + %dumped) + '((bgcolor "green")) + '())) + ,(column-name column)))) + (table-columns table))))) + +(define (table->graphviz-node table) + "Convert TABLE to graphviz node, and return it." + ((@@ (ccwl graphviz) graph-node) + (table-name table) + `((shape . "record") + (style . "filled") + (fillcolor . ,(if (dumped-table? table) + "lightgrey" "white")) + (label . ,(table-label table))))) + (define (dump-schema db) (let ((tables (tables db))) (graph->dot ((@@ (ccwl graphviz) graph) 'schema - #:nodes (map (lambda (table) - ((@@ (ccwl graphviz) graph-node) - (table-name table) - `((shape . "record") - (style . "filled") - (fillcolor . ,(if (find (match-lambda - ((dumped-table . _) - (string=? (symbol->string dumped-table) - (table-name table)))) - %dumped) - "lightgrey" - "white")) - (label . ,(sxml->graphviz-html - `(table (@ (border 0)) - (tr (td (@ (border 1) - (bgcolor ,(human-units-color (table-size table)))) - ,(format #f "~a (~a)" - (table-name table) - (human-units (table-size table))))) - ,@(map (lambda (column) - `(tr (td (@ ,@(if (member (cons (string->symbol (table-name table)) - (string->symbol (column-name column))) - %dumped) - '((bgcolor "green")) - '())) - ,(column-name column)))) - (table-columns table)))))))) - tables) + #:nodes (map table->graphviz-node tables) #:edges (append-map (lambda (table) (filter-map (lambda (column) (and=> (cond -- cgit v1.2.3