aboutsummaryrefslogtreecommitdiff
path: root/ccwl/conditions.scm
blob: c6523cbfd95fbbd2bc4f525eb8e35b28fa0a1b0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
;;; ccwl --- Concise Common Workflow Language
;;; Copyright © 2022 Arun Isaac <arunisaac@systemreboot.net>
;;;
;;; This file is part of ccwl.
;;;
;;; ccwl is free software: you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation, either version 3 of the License, or
;;; (at your option) any later version.
;;;
;;; ccwl is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
;;; General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with ccwl.  If not, see <https://www.gnu.org/licenses/>.

(define-module (ccwl conditions)
  #:use-module (rnrs conditions)
  #:use-module (srfi srfi-28)
  #:export (ccwl-violation
            ccwl-violation?
            ccwl-violation-file
            ccwl-violation-line
            ccwl-violation-column
            unrecognized-keyword-assertion
            unrecognized-keyword-assertion?
            invalid-keyword-arity-assertion
            invalid-keyword-arity-assertion?
            invalid-positional-arguments-arity-assertion
            invalid-positional-arguments-arity-assertion?
            formatted-message
            formatted-message?
            formatted-message-format
            formatted-message-arguments))

(define-condition-type &ccwl-violation &violation
  make-ccwl-violation ccwl-violation?
  (file ccwl-violation-file)
  (line ccwl-violation-line)
  (column ccwl-violation-column))

(define (ccwl-violation x)
  "Return &ccwl-violation condition for syntax X."
  (let ((properties (syntax-source x)))
    (make-ccwl-violation (assq-ref properties 'filename)
                         (assq-ref properties 'line)
                         (assq-ref properties 'column))))

(define-condition-type &unrecognized-keyword-assertion &assertion
  unrecognized-keyword-assertion unrecognized-keyword-assertion?)

(define-condition-type &invalid-keyword-arity-assertion &assertion
  invalid-keyword-arity-assertion invalid-keyword-arity-assertion?)

(define-condition-type &invalid-positional-arguments-arity-assertion &assertion
  invalid-positional-arguments-arity-assertion invalid-positional-arguments-arity-assertion?)

(define-condition-type &formatted-message &message
  make-formatted-message formatted-message?
  (format formatted-message-format)
  (arguments formatted-message-arguments))

(define (formatted-message format-string . arguments)
  "Return &ccwl-message condition for FORMAT-STRING with ARGUMENTS."
  (make-formatted-message (apply format format-string arguments)
                          format-string
                          arguments))