diff options
| author | Arun Isaac | 2022-01-04 15:37:39 +0530 | 
|---|---|---|
| committer | Arun Isaac | 2022-01-04 15:40:26 +0530 | 
| commit | d78b6dea8495b5d117b0da987a3d28d2f197f328 (patch) | |
| tree | 76bdc415a63e5ffb54cdae706e889ba310a3674c /dump.scm | |
| parent | b2da78deceeb036399b4a980eb1c659d4cf3232a (diff) | |
| download | gn-transform-databases-d78b6dea8495b5d117b0da987a3d28d2f197f328.tar.gz | |
Eval macro helper functions at macro expansion time.
If these macro helper functions are not evaluated at macro expansion time, the dependent macros will fail to compile. * dump.scm (string->identifier, field->key, field->assoc-ref, collect-fields, find-clause, remove-namespace, column-id, dump-id): Eval at macro expansion time.
Diffstat (limited to 'dump.scm')
| -rwxr-xr-x | dump.scm | 136 | 
1 files changed, 69 insertions, 67 deletions
| diff --git a/dump.scm b/dump.scm index 87e094a..112cc1a 100755 --- a/dump.scm +++ b/dump.scm @@ -101,16 +101,17 @@ association list mapping substrings to their replacements." str replacement-alist)) -(define (string->identifier prefix str) - "Convert STR to a turtle identifier after replacing illegal +(eval-when (expand load eval) + (define (string->identifier prefix str) + "Convert STR to a turtle identifier after replacing illegal characters with an underscore and prefixing with gn:PREFIX." - (string->symbol - (string-append "gn:" prefix "_" - (string-map (lambda (c) - (case c - ((#\/ #\< #\> #\+ #\( #\) #\space #\@) #\_) - (else c))) - (string-downcase str))))) + (string->symbol + (string-append "gn:" prefix "_" + (string-map (lambda (c) + (case c + ((#\/ #\< #\> #\+ #\( #\) #\space #\@) #\_) + (else c))) + (string-downcase str)))))) (define (snake->lower-camel str) (let ((char-list (string->list str))) @@ -155,65 +156,66 @@ characters with an underscore and prefixing with gn:PREFIX." (list subject predicate object))) (format #t "~a ~a ~s .~%" subject predicate object)) -(define (field->key x) - (translate-forms 'field - (lambda (x) - #`(key #,(symbol->string - (syntax->datum - ((syntax-rules (field) - ((field table column) column) - ((field table column alias) alias)) - x))))) - x)) - -(define (field->assoc-ref alist x) - "Recursively translate field references in source X to (assoc-ref +(eval-when (expand load eval) + (define (field->key x) + (translate-forms 'field + (lambda (x) + #`(key #,(symbol->string + (syntax->datum + ((syntax-rules (field) + ((field table column) column) + ((field table column alias) alias)) + x))))) + x)) + + (define (field->assoc-ref alist x) + "Recursively translate field references in source X to (assoc-ref ALIST field-name) forms." - (translate-forms 'field - (lambda (x) - #`(assoc-ref #,alist - #,(symbol->string - (syntax->datum - ((syntax-rules (field) - ((field table column) column) - ((field table column alias) alias)) - x))))) - x)) - -(define (collect-fields x) - (map (syntax-rules (field) - ((field reference ...) - (reference ...))) - (collect-forms 'field x))) - -(define (find-clause clauses key) - "Find (KEY ...) clause among CLAUSES, a list of syntax forms." - (find (lambda (x) - (syntax-case x () - ((clause-key _ ...) - (eq? (syntax->datum #'clause-key) - key)))) - clauses)) - -(define (remove-namespace str) - "Remove RDF namespace prefix from STR." - (substring str (1+ (string-index str #\:)))) - -(define (column-id table-name column-name) - (string->identifier - "field" (string-append - ;; We downcase table names in identifiers. So, we - ;; distinguish between the user and User tables. - (if (string=? table-name "User") - "user2" table-name) - "__" column-name))) - -(define (dump-id dump-table predicate) - (symbol->string - (string->identifier - "dump" - (string-append - dump-table "_" (remove-namespace (symbol->string predicate)))))) + (translate-forms 'field + (lambda (x) + #`(assoc-ref #,alist + #,(symbol->string + (syntax->datum + ((syntax-rules (field) + ((field table column) column) + ((field table column alias) alias)) + x))))) + x)) + + (define (collect-fields x) + (map (syntax-rules (field) + ((field reference ...) + (reference ...))) + (collect-forms 'field x))) + + (define (find-clause clauses key) + "Find (KEY ...) clause among CLAUSES, a list of syntax forms." + (find (lambda (x) + (syntax-case x () + ((clause-key _ ...) + (eq? (syntax->datum #'clause-key) + key)))) + clauses)) + + (define (remove-namespace str) + "Remove RDF namespace prefix from STR." + (substring str (1+ (string-index str #\:)))) + + (define (column-id table-name column-name) + (string->identifier + "field" (string-append + ;; We downcase table names in identifiers. So, we + ;; distinguish between the user and User tables. + (if (string=? table-name "User") + "user2" table-name) + "__" column-name))) + + (define (dump-id dump-table predicate) + (symbol->string + (string->identifier + "dump" + (string-append + dump-table "_" (remove-namespace (symbol->string predicate))))))) (define-syntax syntax-let (syntax-rules () | 
