From 453570bdc944cbd534930e2d25be8d967a21aa85 Mon Sep 17 00:00:00 2001 From: Cadence Ember Date: Wed, 8 Mar 2023 22:56:04 +1300 Subject: [PATCH] Replace define-runtime-path with custom anytime-path function --- lib/mime.types | 2 ++ lib/syntax.rkt | 42 ++++++++++++++++++++++++++++++++++--- src/data.rkt | 6 +++--- src/page-static-archive.rkt | 4 ++-- src/page-static.rkt | 3 ++- src/page-wiki-offline.rkt | 4 ++-- 6 files changed, 50 insertions(+), 11 deletions(-) diff --git a/lib/mime.types b/lib/mime.types index 74ddeeff..d31a2acc 100644 --- a/lib/mime.types +++ b/lib/mime.types @@ -1,5 +1,6 @@ text/html html text/css css +application/xml xml text/xml xml image/gif gif image/jpeg jpeg @@ -25,6 +26,7 @@ application/font-woff2 woff2 application/acad woff2 font/woff2 woff2 application/font-woff woff +font/woff woff application/x-font-ttf ttf application/x-font-truetype ttf application/x-truetype-font ttf diff --git a/lib/syntax.rkt b/lib/syntax.rkt index 10267dd4..a587e03a 100644 --- a/lib/syntax.rkt +++ b/lib/syntax.rkt @@ -1,5 +1,5 @@ #lang racket/base -(require (for-syntax racket/base)) +(require (for-syntax racket/base syntax/location)) (provide ; help make a nested if. if/in will gain the same false form of its containing if/out. @@ -7,7 +7,12 @@ ; cond, but values can be defined between conditions cond/var ; wrap sql statements into lambdas so they can be executed during migration - wrap-sql) + wrap-sql + ; get the name of the file that contains the currently evaluating form + this-directory + this-file + ; replacement for define-runtime-path + anytime-path) (module+ test (require rackunit) @@ -96,6 +101,16 @@ (check-equal? (if/out #t (if/in #f 'yes) 'no) 'no) (check-equal? (if/out #f (if/in #f 'yes) 'no) 'no)) +(define-syntax (this-directory stx) + (datum->syntax stx (syntax-source-directory stx))) + +(define-syntax (this-file stx) + (datum->syntax stx (build-path (or (syntax-source-directory stx) 'same) (syntax-source-file-name stx)))) + +(module+ test + (require racket/path) + (check-equal? (file-name-from-path (this-file)) (build-path "syntax.rkt"))) + (define-syntax (cond/var stx) (transform/out-cond/var stx)) (module+ test @@ -103,7 +118,28 @@ #'(cond [#f 0] [#t - (let ([d (* a 2)]) + (let* ([d (* a 2)]) (cond [(eq? d 8) d] [#t "not 4"]))]))) + +;;; Replacement for define-runtime-path that usually works well and doesn't include the files/folder contents into the distribution. +;;; When running from source, should always work appropriately. +;;; When running from a distribution, (current-directory) is treated as the root. +;;; Usage: +;;; * to-root : Path-String * relative path from the source file to the project root +;;; * to-dest : Path-String * relative path from the root to the desired file/folder +(define-syntax (anytime-path stx) + (define-values (_ to-root to-dest) (apply values (syntax->list stx))) + (define source (syntax-source stx)) + (unless (complete-path? source) + (error 'anytime-path "syntax source has no directory: ~v" stx)) + (datum->syntax + stx + `(let* ([syntax-to-root (build-path (path-only ,source) ,to-root)] + [root (if (directory-exists? syntax-to-root) + ;; running on the same filesystem it was compiled on, i.e. it's running the source code out of a directory, and the complication is the intermediate compilation + syntax-to-root + ;; not running on the same filesystem, i.e. it's a distribution. we assume that the current working directory is where the executable is, and treat this as the root. + (current-directory))]) + (simple-form-path (build-path root ,to-dest))))) diff --git a/src/data.rkt b/src/data.rkt index 35024d20..cb4e194b 100644 --- a/src/data.rkt +++ b/src/data.rkt @@ -8,8 +8,8 @@ db memo "static-data.rkt" - "../lib/url-utils.rkt" "whole-utils.rkt" + "../lib/url-utils.rkt" "../lib/xexpr-utils.rkt" "../archiver/archiver-database.rkt" "config.rkt") @@ -42,8 +42,8 @@ [(config-true? 'feature_offline::only) (when (config-true? 'debug) (printf "using offline mode for siteinfo ~a~n" wikiname)) - (define row (query-maybe-row slc "select sitename, basepage, license_text, license_url from wiki where wikiname = ?" - wikiname)) + (define row (query-maybe-row* "select sitename, basepage, license_text, license_url from wiki where wikiname = ?" + wikiname)) (if row (siteinfo^ (vector-ref row 0) (vector-ref row 1) diff --git a/src/page-static-archive.rkt b/src/page-static-archive.rkt index cfd5ab6d..c0c2e09c 100644 --- a/src/page-static-archive.rkt +++ b/src/page-static-archive.rkt @@ -2,7 +2,6 @@ (require racket/file racket/path racket/port - racket/runtime-path racket/string net/url web-server/http @@ -11,6 +10,7 @@ (only-in web-server/dispatchers/dispatch next-dispatcher) "../archiver/archiver.rkt" "../lib/mime-types.rkt" + "../lib/syntax.rkt" "../lib/xexpr-utils.rkt" "config.rkt" "log.rkt") @@ -18,7 +18,7 @@ (provide page-static-archive) -(define-runtime-path path-archive "../storage/archive") +(define path-archive (anytime-path ".." "storage/archive")) (define ((replacer wikiname) whole url) (format diff --git a/src/page-static.rkt b/src/page-static.rkt index e2c984e7..03112299 100644 --- a/src/page-static.rkt +++ b/src/page-static.rkt @@ -8,6 +8,7 @@ (only-in web-server/dispatchers/dispatch next-dispatcher) (prefix-in files: web-server/dispatchers/dispatch-files) "../lib/mime-types.rkt" + "../lib/syntax.rkt" "config.rkt") (provide @@ -17,7 +18,7 @@ (require rackunit)) (define-runtime-path path-static "../static") -(define-runtime-path path-archive "../storage/archive") +(define path-archive (anytime-path ".." "storage/archive")) (define hash-ext-mime-type (hash #".css" #"text/css" diff --git a/src/page-wiki-offline.rkt b/src/page-wiki-offline.rkt index a3986da8..37832715 100644 --- a/src/page-wiki-offline.rkt +++ b/src/page-wiki-offline.rkt @@ -4,7 +4,7 @@ racket/function racket/list racket/match - racket/runtime-path + racket/path racket/string ; libs (prefix-in easy: net/http-easy) @@ -38,7 +38,7 @@ (module+ test (require rackunit)) -(define-runtime-path path-archive "../storage/archive") +(define path-archive (anytime-path ".." "storage/archive")) (define (page-wiki-offline req) (response-handler