diff options
author | Hugo Hörnquist <hugo@lysator.liu.se> | 2020-08-17 18:23:08 +0200 |
---|---|---|
committer | Hugo Hörnquist <hugo@lysator.liu.se> | 2020-08-17 18:24:12 +0200 |
commit | 55f80b2ca4c8d44255e38ef2eee4564501aa83ae (patch) | |
tree | 9b8fbec23f0f88a503d28e8370659a2bcb0f481f /module/output/vdir.scm | |
parent | even more. (diff) | |
download | calp-55f80b2ca4c8d44255e38ef2eee4564501aa83ae.tar.gz calp-55f80b2ca4c8d44255e38ef2eee4564501aa83ae.tar.xz |
MOORE
Diffstat (limited to 'module/output/vdir.scm')
-rw-r--r-- | module/output/vdir.scm | 55 |
1 files changed, 0 insertions, 55 deletions
diff --git a/module/output/vdir.scm b/module/output/vdir.scm deleted file mode 100644 index 2541f0f9..00000000 --- a/module/output/vdir.scm +++ /dev/null @@ -1,55 +0,0 @@ -;;; Commentary: -;;; Module for writing components to the vdir storage format. -;;; Currently also has some cases for "big" icalendar files, -;;; but those are currently unsupported. - -;;; TODO generalize save-event and remove-event into a general interface, -;;; which different database backends can implement. Actually, do that for all -;;; loading and writing. - -;;; Code: - -(define-module (output vdir) - :use-module (util) - :use-module (vcomponent ical output) - :use-module (vcomponent) - :use-module ((util io) :select (with-atomic-output-to-file)) - ) - - -(define / file-name-separator-string) - -(define-public (save-event event) - (define calendar (parent event)) - (case (prop calendar '-X-HNH-SOURCETYPE) - [(file) - (error "Importing into direct calendar files not supported")] - - [(vdir) - (let* ((uid (or (prop event 'UID) (uuidgen)))) - (set! (prop event 'UID) uid - ;; TODO use existing filename if present? - (prop event '-X-HNH-FILENAME) (string-append - (prop calendar '-X-HNH-DIRECTORY) - / uid ".ics")) - (with-atomic-output-to-file (prop event '-X-HNH-FILENAME) - (lambda () (print-components-with-fake-parent (list event)))) - uid)] - - [else - (error "Source of calendar unknown, aborting.") - ])) - - -(define-public (remove-event event) - (define calendar (parent event)) - (case (prop calendar '-X-HNH-SOURCETYPE) - [(file) - (error "Removing events from large files unsupported")] - - [(vdir) - (delete-file (prop event '-X-HNH-FILENAME))] - - [else - (error "Source of calendar unknown, aborting.") - ])) |