File: README.md

package info (click to toggle)
tools-trace-clojure 0.7.9-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 156 kB
  • sloc: makefile: 25; xml: 21
file content (138 lines) | stat: -rw-r--r-- 4,437 bytes parent folder | download | duplicates (3)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
clojure.tools.trace
========================================

A Clojure trace tool. Defines tracing macros/fns to help you see what your code is doing.

Formerly known as clojure.contrib.trace.

See the [tools.trace API Reference](http://clojure.github.io/tools.trace/).


Releases and Dependency Information
========================================

Latest stable release: 0.7.9

* [All Released Versions](http://search.maven.org/#search|ga|1|g%3A%22org.clojure%22%20AND%20a%3A%22tools.trace%22)

* [Development Snapshot Versions](https://oss.sonatype.org/index.html#nexus-search;gav~org.clojure~tools.trace~~~)

[Leiningen](https://github.com/technomancy/leiningen) dependency information:

```clojure
    [org.clojure/tools.trace "0.7.9"]
```
    
[Maven](http://maven.apache.org/) dependency information:
```xml
    <dependency>
      <groupId>org.clojure</groupId>
      <artifactId>tools.trace</artifactId>
      <version>0.7.8</version>
    </dependency>
```



Example Usage
========================================
```clojure
=> (use 'clojure.tools.trace)

=> (trace (* 2 3)) ;; To trace a value
TRACE: 6
6

=> (trace "tag" (* 2 3)) ;; To trace a value and assign a trace tag
TRACE tag: 6
6

=> (deftrace fubar [x v] (+ x v)) ;; To trace a function call and its return value
=> (fubar 2 3)
TRACE t1107: (fubar 2 3)
TRACE t1107: => 5
5

=> (do (+ 1 3) (* 5 6) (/ 1 0))
ArithmeticException Divide by zero  clojure.lang.Numbers.divide (Numbers.java:156)
=> (trace-forms (+ 1 3) (* 5 6) (/ 1 0)) ;; To identify which form is failing
ArithmeticException Divide by zero
  Form failed: (/ 1 0)
  clojure.lang.Numbers.divide (Numbers.java:156)

(trace-ns myown.namespace) ;; To dynamically trace/untrace all fns in a name space (untrace-ns myown.namespace)

(trace-vars myown.namespace/fubar) ;; To dynamically trace/untrace specific fns (untrace-vars myown.namespace/fubar)
 
```



Developer Information
========================================

* [GitHub project](https://github.com/clojure/tools.trace)

* [Bug Tracker](http://dev.clojure.org/jira/browse/TTRACE)

* [Continuous Integration](http://build.clojure.org/job/tools.trace/)

* [http://build.clojure.org/job/tools.trace-test-matrix/)



Change Log
====================
* Release 0.7.9 October 8, 2015: Luc Préfontaine
  * Closed TTRACE-11, trace-vars/untrace-vars now accept vars
  * Closed TTRACE-12, move away from Java 5, extend some new throwables with ThrowableRecompose  
  * Added more tests for TTRACE-12

* Release 0.7.8 March 15, 2013: Luc Préfontaine
  * Fixed README

* Release 0.7.7 March 14, 2013: Luc Préfontaine
  * Replaced def by declare in deftrace macro
  * Remove unnecessary call to run-tests in test suite
  * Trace only functions in trace-vars*
  * Added missing cond in clone-throwable on a Throwable
  * Do not allow trace-vars* to reapply tracing on an already traced function

* Release 0.7.6 Aug 23, 2013: Luc Préfontaine
  * Fixed crash of throwable tracing when no string based constructor exists

* Release 0.7.5 Dec 1, 2012: Luc Préfontaine
  * Fixed README and comments in source file

* Release 0.7.4 Dec 1, 2012: Luc Préfontaine
  * added traced? and traceable/ fns
  * removed reflection warnings
  
* Release 0.7.3 March 4, 2012: Luc Préfontaine
  * added macro wrappers around fns allowing dynamic tracing.

* Release 0.7.2 Feb. 20, 2012: Luc Préfontaine
  * added contribution from Michał Marczyk and Don Jackson to allow dynamic tracing of fn vars and all fns in a given namespace.
* Release 0.7.1 on 2011-09-18
  * moved it to new contrib modular struct
  * made it 1.2/1.3 compliant
  * supported doc strings
  * added a trace-form macro, from Jonathan Fischer
* Changes from clojure.trace
  * replaced *trace-out* with tracer
  * made trace a function instead of a macro (suggestion from Stuart Halloway)
  * added trace-fn-call



Copyright and License
========================================

Copyright (c) Stuart Sierra, Michel Salim, Luc Préfontaine, Jonathan Fischer Friberg, Michał Marczyk, 2011-2012.
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.