aboutsummaryrefslogtreecommitdiff
path: root/module/glob.scm
diff options
context:
space:
mode:
authorHugo Hörnquist <hugo@lysator.liu.se>2022-03-17 22:14:18 +0100
committerHugo Hörnquist <hugo@lysator.liu.se>2022-03-28 14:17:01 +0200
commit1da5a277188a954d881316cb605962ee66053285 (patch)
tree4f77be46498f321d08bfaa072636e4fd252b4f9d /module/glob.scm
parentUnsmarted define-config% (diff)
downloadcalp-1da5a277188a954d881316cb605962ee66053285.tar.gz
calp-1da5a277188a954d881316cb605962ee66053285.tar.xz
Normalize errors.
Diffstat (limited to 'module/glob.scm')
-rw-r--r--module/glob.scm11
1 files changed, 8 insertions, 3 deletions
diff --git a/module/glob.scm b/module/glob.scm
index a436b810..82489565 100644
--- a/module/glob.scm
+++ b/module/glob.scm
@@ -6,8 +6,10 @@
(define (glob-err epath eerrno)
- (error "Glob errored on ~s with errno = ~a"
- (pointer->string epath) eerrno))
+ (scm-error 'misc-error "glob-err"
+ "Glob errored on ~s with errno = ~a"
+ (list (pointer->string epath) eerrno)
+ #f))
;; NOTE there really should be an (c eval) module, to resolve symbols such as
;; @var{<<}.
@@ -29,7 +31,10 @@
(procedure->pointer int glob-err (list '* int))
(bytevector->pointer bv))))
(unless (zero? globret)
- (error "Globret errror ~a" globret))
+ (scm-error 'misc-error "glob"
+ "Globret errror ~a"
+ (list globret)
+ #f))
(let* ((globstr (parse-c-struct (bytevector->pointer bv) (list size_t '* size_t)))
(strvec (pointer->bytevector (cadr globstr) (car globstr) 0
(string->symbol (format #f "u~a" (* 8 (sizeof '*))))))