aboutsummaryrefslogtreecommitdiff
path: root/src/clojure/contrib/condition/example.clj
blob: 5a7d72efbfd95c8d69f7519c8211b331d42ac862 (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
;;  Copyright (c) Stephen C. Gilardi. All rights reserved.  The use and
;;  distribution terms for this software are covered by the Eclipse Public
;;  License 1.0 (http://opensource.org/licenses/eclipse-1.0.php) which can
;;  be found in the file epl-v10.html at the root of this distribution.  By
;;  using this software in any fashion, you are agreeing to be bound by the
;;  terms of this license.  You must not remove this notice, or any other,
;;  from this software.
;;
;;  clojure.contrib.condition.example.clj
;;
;;  scgilardi (gmail)
;;  Created 09 June 2009

(ns clojure.contrib.condition.example
  (:use (clojure.contrib
         [condition
          :only (handler-case print-stack-trace raise *condition*)])))

(defn func [x y]
  "Raises an exception if x is negative"
  (when (neg? x)
    (raise :type :illegal-argument :arg 'x :value x))
  (+ x y))

(defn main
  []
  
  ;; simple handler
  
  (handler-case :type
    (println (func 3 4))
    (println (func -5 10))
    (handle :illegal-argument
            (print-stack-trace *condition*))
    (println 3))

  ;; multiple handlers
  
  (handler-case :type
    (println (func 4 1))
    (println (func -3 22))
    (handle :overflow
      (print-stack-trace *condition*))
    (handle :illegal-argument
      (print-stack-trace *condition*)))

  ;; nested handlers

  (handler-case :type
    (handler-case :type
      nil
      nil
      (println 1)
      (println 2)
      (println 3)
      (println (func 8 2))
      (println (func -6 17))
      ;; no handler for :illegal-argument
      (handle :overflow
        (println "nested")
        (print-stack-trace *condition*)))
    (println (func 3 4))
    (println (func -5 10))
    (handle :illegal-argument
      (println "outer")
      (print-stack-trace *condition*))))