preference directory functionality added

This commit is contained in:
2025-08-04 13:25:33 +02:00
parent ae43b87758
commit 8318be1420
2 changed files with 15 additions and 4 deletions

View File

@@ -10,8 +10,15 @@
make-ini
)
(define (get-ini-file f)
(if (symbol? f)
(let* ((pref-dir (find-system-path 'pref-dir)))
(build-path pref-dir (string-append (symbol->string f) ".ini")))
(build-path f)))
(define (ini->file ini file)
(let ((out (open-output-file file #:exists 'replace)))
(let ((out (open-output-file (get-ini-file file) #:exists 'replace)))
(let ((last-is-newline #f))
(for-each (lambda (section)
(let ((section-name (car section)))
@@ -64,8 +71,9 @@
#f)
s)))))))
(define (file->ini file)
(let* ((lines (file->lines file))
(define (file->ini file*)
(let* ((file (get-ini-file file*))
(lines (if (file-exists? file) (file->lines file) '()))
(re-section #px"^\\[([a-zA-Z0-9_-]+)\\]$")
(re-keyval #px"^([a-zA-Z0-9_-]+)[=](.*)$")
(re-comment #px"^[;](.*)$"))

View File

@@ -23,6 +23,8 @@
@defproc[(file->ini [file path-string?]) mc-pair?]{
Reads an INI file from disk and parses it into an internal mutable cons pair (mc-pair) structure.
If the file does noet exist, an empty ini structure is made.
If file is a symbol?, the file will be constructed from the prefs-dir, the symbol and a suffix ".ini".
The parser supports:
@@ -42,7 +44,8 @@
}
@defproc[(ini->file [ini mc-pair?] [file path-string?]) void?]{
Writes an INI structure (as produced by @racket[file->ini] or @racket[make-ini]) to the specified file.
Writes an INI structure (as produced by @racket[file->ini] or @racket[make-ini]) to the specified file.
If file is a symbol?, the file will be constructed from the prefs-dir, the symbol and a suffix ".ini".
The output preserves:
@itemlist[