dotfiles/setup/common.rkt
2023-11-04 11:51:11 +01:00

144 lines
5.3 KiB
Racket

#lang racket
(provide build-haxe
cmd
copy
define-logging
generate-cgopt-json
install-link
install-roswell
install-rust
install-script?
install-zig
load-config
log-calls
output-bin-path
rm)
;; A parameter containing a predicate string? -> boolean? for checking if a script should be installed.
(define/contract install-script?
(parameter/c (string? . -> . boolean?))
(make-parameter (const #t)))
(define-namespace-anchor common-ns)
(define (load-config)
(let ([path (expand-user-path "~/.config/mzte_localconf/setup-opts.rkts")])
(if (file-exists? path)
(parameterize ([current-namespace (namespace-anchor->namespace common-ns)])
(load path))
(fprintf (current-error-port) "no setup-opts found, skipping\n"))))
;; Whether to log calls or not
(define log-calls (make-parameter #t))
;; Default output path
(define output-bin-path (make-parameter (build-path (find-system-path 'home-dir) ".local")))
(define (display-function-call func args)
(when (log-calls)
(fprintf (current-error-port)
"\x1b[1;30m(\x1b[1;32m~s\x1b[1;33m~a\x1b[1;30m)\x1b[0m\n"
func
(string-append (if (null? args) "" " ") (apply ~a #:separator " " args)))))
;; Defines an alias to a function which will log it's parameters on invokation.
(define-syntax (define-logging stx)
(syntax-case stx ()
[(_ (name arg ...) body ...)
(syntax-case (cons #'list
(map (λ (a) (if (list? (syntax->list a)) (car (syntax->list a)) a))
(syntax->list #'(arg ...))))
()
[display-args
#'(define (name arg ...)
(display-function-call 'name display-args)
body ...)])]
[(_ (name arg ... . more) body ...)
(syntax-case (cons #'list
(map (λ (a) (if (list? (syntax->list a)) (car (syntax->list a)) a))
(syntax->list #'(arg ...))))
()
[display-args
#'(define (name arg ... . more)
(display-function-call 'name (append display-args more))
body ...)])]
[(_ name val)
#'(define (name . args)
(display-function-call 'name args)
(apply val args))]))
;; Defines a script installer with a backing function which will only run when install-script? returns #t.
(define-syntax (define-script-installer stx)
(syntax-case stx ()
[(_ (name script arg ...) body ...)
(syntax-case (cons #'list
(map (λ (a) (if (list? (syntax->list a)) (car (syntax->list a)) a))
(syntax->list #'(script arg ...))))
()
[display-args
#'(define (name script arg ...)
(display-function-call 'name display-args)
(if ((install-script?) script)
(begin
body ...)
(fprintf (current-error-port) "skipping script ~s\n" script)))])]
[(_ (name script arg ... . more) body ...)
(syntax-case (cons #'list
(map (λ (a) (if (list? (syntax->list a)) (car (syntax->list a)) a))
(syntax->list #'(script arg ...))))
()
[display-args
#'(define (name script arg ... . more)
(display-function-call 'name (append display-args more))
(if ((install-script?) script)
(begin
body ...)
(fprintf (current-error-port) "skipping script ~s\n" (car args))))])]))
(define-logging (cmd exe . args)
(unless (apply system* (find-executable-path exe) args)
(raise-user-error "Command Failed")))
(define-logging (rm path) (delete-directory/files path #:must-exist? false))
(define-logging copy copy-directory/files)
(define-script-installer
(install-zig path [mode "ReleaseFast"])
(parameterize ([current-directory path] [log-calls #f])
(cmd "zig" "build" "-p" (output-bin-path) (string-append "-Doptimize=" mode))))
(define-script-installer (install-link from to)
(with-handlers ([exn:fail? (const #f)])
(delete-file to))
(make-file-or-directory-link (normalize-path from) to))
(define-script-installer (install-rust path)
(parameterize ([current-directory path] [log-calls #f])
(cmd "cargo"
"-Z"
"unstable-options"
"build"
"--release"
"--out-dir"
(build-path (output-bin-path) "bin"))))
(define-logging (build-haxe path)
(parameterize ([current-directory path] [log-calls #f])
(cmd "haxe" "build.hxml")))
(define-logging (generate-cgopt-json)
(unless (directory-exists? "cgout")
(make-directory "cgout"))
(call-with-output-file* #:exists 'truncate/replace
"cgout/opts.json"
(λ (outfile)
(parameterize ([log-calls #f] [current-output-port outfile])
(cmd "confgen" "--json-opt" "confgen.lua")))))
(define-script-installer (install-roswell path)
(parameterize ([log-calls #f])
(match-let*-values ([(_ filename _) (split-path path)]
[(outpath)
(build-path (output-bin-path) "bin" (path-replace-extension filename ""))])
(cmd "ros" "dump" "executable" path "-o" outpath))))