feat(sterni/mblog): implement environment based config mechanism

Change-Id: I091c0d5decc0a1eb3d24e81b713434ab391c677d
Reviewed-on: https://cl.tvl.fyi/c/depot/+/8347
Reviewed-by: sterni <sternenseemann@systemli.org>
Autosubmit: sterni <sternenseemann@systemli.org>
Tested-by: BuildkiteCI
This commit is contained in:
sterni 2023-03-17 17:36:57 +01:00 committed by clbot
parent fee0c83915
commit 80e168b22d
6 changed files with 54 additions and 14 deletions

View file

@ -1,5 +1,5 @@
;; SPDX-License-Identifier: GPL-3.0-only ;; SPDX-License-Identifier: GPL-3.0-only
;; SPDX-FileCopyrightText: Copyright (C) 2022 by sterni ;; SPDX-FileCopyrightText: Copyright (C) 2022-2023 by sterni
(in-package :cli) (in-package :cli)
(declaim (optimize (safety 3))) (declaim (optimize (safety 3)))
@ -49,6 +49,7 @@
(defun main () (defun main ()
"Dispatch to correct main function based on arguments and UIOP:ARGV0." "Dispatch to correct main function based on arguments and UIOP:ARGV0."
(config:init-from-env)
(multiple-value-bind (flags args) (multiple-value-bind (flags args)
(partition-by (lambda (x) (starts-with #\- x)) (partition-by (lambda (x) (starts-with #\- x))
(uiop:command-line-arguments)) (uiop:command-line-arguments))

View file

@ -0,0 +1,31 @@
;; SPDX-License-Identifier: GPL-3.0-only
;; SPDX-FileCopyrightText: Copyright (C) 2023 by sterni
(in-package :config)
(eval-when (:compile-toplevel :load-toplevel)
(defun plist-to-alist (lst)
(loop for (name . (default . (parser . nil))) on lst by #'cdddr
collect (cons name (list default parser))))
(defun symbol-to-env-var-name (symbol)
(concatenate 'string
"MBLOG_"
(string-upcase
(remove #\* (substitute #\_ #\- (string symbol)))))))
(defmacro define-configuration-variables (&rest args)
(let ((vars (plist-to-alist args))
(val-var-sym (gensym)))
`(progn
,@(loop for (name . (default nil)) in vars
collect `(defvar ,name ,default))
(defun init-from-env ()
,@(loop for (name . (nil parser)) in vars
collect
`(when-let ((,val-var-sym (getenv ,(symbol-to-env-var-name name))))
(setf ,name (funcall ,parser ,val-var-sym))))))))
(define-configuration-variables
*general-buffer-size* 4096 #'parse-integer)

View file

@ -1,5 +1,5 @@
# SPDX-License-Identifier: GPL-3.0-only # SPDX-License-Identifier: GPL-3.0-only
# SPDX-FileCopyrightText: Copyright (C) 2022 by sterni # SPDX-FileCopyrightText: Copyright (C) 2022-2023 by sterni
{ depot, pkgs, ... }: { depot, pkgs, ... }:
(depot.nix.buildLisp.program { (depot.nix.buildLisp.program {
@ -7,6 +7,7 @@
srcs = [ srcs = [
./packages.lisp ./packages.lisp
./config.lisp
./maildir.lisp ./maildir.lisp
./transformer.lisp ./transformer.lisp
./note.lisp ./note.lisp

View file

@ -1,5 +1,5 @@
;; SPDX-License-Identifier: GPL-3.0-only ;; SPDX-License-Identifier: GPL-3.0-only
;; SPDX-FileCopyrightText: Copyright (C) 2022 by sterni ;; SPDX-FileCopyrightText: Copyright (C) 2022-2023 by sterni
;; SPDX-FileCopyrightText: Copyright (C) 2006-2010 by Walter C. Pelissero ;; SPDX-FileCopyrightText: Copyright (C) 2006-2010 by Walter C. Pelissero
(in-package :mblog) (in-package :mblog)
@ -26,12 +26,10 @@
:if-does-not-exist :create) :if-does-not-exist :create)
,@body)) ,@body))
(defvar *copy-buffer-size* 4096)
(defun redirect-stream (in out) (defun redirect-stream (in out)
"Consume input stream IN and write all its content to output stream OUT. "Consume input stream IN and write all its content to output stream OUT.
The streams' element types need to match." The streams' element types need to match."
(let ((buf (make-array *copy-buffer-size* :element-type (stream-element-type in)))) (let ((buf (make-array config:*general-buffer-size* :element-type (stream-element-type in))))
(loop for pos = (read-sequence buf in) (loop for pos = (read-sequence buf in)
while (> pos 0) while (> pos 0)
do (write-sequence buf out :end pos)))) do (write-sequence buf out :end pos))))

View file

@ -1,18 +1,15 @@
;; SPDX-License-Identifier: GPL-3.0-only ;; SPDX-License-Identifier: GPL-3.0-only
;; SPDX-FileCopyrightText: Copyright (C) 2022 by sterni ;; SPDX-FileCopyrightText: Copyright (C) 2022-2023 by sterni
(in-package :note) (in-package :note)
(declaim (optimize (safety 3))) (declaim (optimize (safety 3)))
;;; util ;;; util
;; TODO(sterni): merge this with mblog::*copy-buffer-size*
(defvar *copy-buffer-size* 4096)
(defun html-escape-stream (in out) (defun html-escape-stream (in out)
"Escape characters read from stream IN and write them to "Escape characters read from stream IN and write them to
stream OUT escaped using WHO:ESCAPE-STRING-MINIMAL." stream OUT escaped using WHO:ESCAPE-STRING-MINIMAL."
(let ((buf (make-string *copy-buffer-size*))) (let ((buf (make-string config:*general-buffer-size*)))
(loop for len = (read-sequence buf in) (loop for len = (read-sequence buf in)
while (> len 0) while (> len 0)
do (write-string (who:escape-string-minimal (subseq buf 0 len)) out)))) do (write-string (who:escape-string-minimal (subseq buf 0 len)) out))))

View file

@ -1,5 +1,5 @@
;; SPDX-License-Identifier: GPL-3.0-only ;; SPDX-License-Identifier: GPL-3.0-only
;; SPDX-FileCopyrightText: Copyright (C) 2022 by sterni ;; SPDX-FileCopyrightText: Copyright (C) 2022-2023 by sterni
(defpackage :maildir (defpackage :maildir
(:use :common-lisp) (:use :common-lisp)
@ -8,12 +8,22 @@
(:documentation (:documentation
"Very incomplete package for dealing with maildir(5).")) "Very incomplete package for dealing with maildir(5)."))
(defpackage :config
(:use
:common-lisp)
(:import-from :uiop :getenv)
(:import-from :alexandria :when-let)
(:export
:init-from-env
:*general-buffer-size*))
(defpackage :note (defpackage :note
(:use (:use
:common-lisp :common-lisp
:closure-html :closure-html
:cl-date-time-parser :cl-date-time-parser
:mime4cl) :mime4cl
:config)
(:import-from (:import-from
:alexandria :alexandria
:when-let* :when-let*
@ -36,7 +46,8 @@
:klatre :klatre
:who :who
:maildir :maildir
:note) :note
:config)
(:export :build-mblog) (:export :build-mblog)
(:import-from :local-time :universal-to-timestamp) (:import-from :local-time :universal-to-timestamp)
(:shadowing-import-from :common-lisp :list)) (:shadowing-import-from :common-lisp :list))
@ -46,6 +57,7 @@
:common-lisp :common-lisp
:uiop :uiop
:note :note
:config
:mblog) :mblog)
(:import-from :alexandria :starts-with) (:import-from :alexandria :starts-with)
(:export :main)) (:export :main))