blob: 8cb683aeeb33b275bcb52aab5072f223b11c21c0 (
plain) (
blame)
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
|
/*
Wrap Clean nodes (for debugging purposes).
Version 1.0.1
Ronny Wichers Schreur
ronny@cs.kun.nl
*/
definition module Wrap
from StdOverloaded import toString
:: WrappedDescriptorId
instance toString WrappedDescriptorId
:: WrappedDescriptor
= WrappedDescriptorCons
| WrappedDescriptorNil
| WrappedDescriptorTuple
| WrappedDescriptorOther !WrappedDescriptorId
:: WrappedNode
// basic types
= WrappedInt !Int
| WrappedChar !Char
| WrappedBool !Bool
| WrappedReal !Real
| WrappedFile !File
// unboxed arrays of basic types
| WrappedString !{#Char}
| WrappedIntArray !{#Int}
| WrappedBoolArray !{#Bool}
| WrappedRealArray !{#Real}
| WrappedFileArray !{#File}
// other arrays
| WrappedArray !{WrappedNode}
// records
| WrappedRecord !WrappedDescriptor !{WrappedNode}
// other nodes
| WrappedOther !WrappedDescriptor !{WrappedNode}
wrapNode :: !.a -> WrappedNode
|