aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMunyoki Kilyungi2023-06-29 22:08:15 +0300
committerMunyoki Kilyungi2023-07-21 14:36:35 +0300
commit51b87b5300bbbd415d3a3d3285ba1f93fba53203 (patch)
tree8c8b9a7e80eac759b6056d81a3a80cbaf6c4cb16
parent31825be584da4108d0984a310e8c301516d9bb4f (diff)
downloadgn-transform-databases-51b87b5300bbbd415d3a3d3285ba1f93fba53203.tar.gz
Optionally self-document while dumping
-rw-r--r--dump/special-forms.scm20
1 files changed, 20 insertions, 0 deletions
diff --git a/dump/special-forms.scm b/dump/special-forms.scm
index bd1760b..0099f73 100644
--- a/dump/special-forms.scm
+++ b/dump/special-forms.scm
@@ -439,6 +439,26 @@ must be remedied."
(triple 'predicate 'rdfs:domain #,subject-type))))
(_ (error "Invalid predicate clause:" predicate-clause))))
#'(predicate-clauses ...))))
+ (when (dump-configuration-auto-document-path configuration)
+ (for-each (match-lambda
+ ((predicate . object)
+ (format #f "Subject:~a Predicate:~a Object:~a.~%"
+ #,(car (collect-keys
+ (field->key #'subject)))
+ predicate object)))
+ (map-alist
+ '()
+ #,@(translate-forms 'field
+ (lambda (x)
+ (symbol->string
+ (syntax->datum
+ ((syntax-rules (field)
+ ((field (query alias)) alias)
+ ((field table column) column)
+ ((field table column alias) alias))
+ x))))
+ #'(predicate-clauses ...))
+ )))
(sql-for-each (lambda (row)
(scm->triples
(map-alist row #,@(field->key #'(predicate-clauses ...)))