]> git.saurik.com Git - cycript.git/blob - Replace.hpp
Changed from a threaded pool to a thread-local pool, abstracted out token assignment...
[cycript.git] / Replace.hpp
1 /* Cycript - Inlining/Optimizing JavaScript Compiler
2 * Copyright (C) 2009 Jay Freeman (saurik)
3 */
4
5 /* Modified BSD License {{{ */
6 /*
7 * Redistribution and use in source and binary
8 * forms, with or without modification, are permitted
9 * provided that the following conditions are met:
10 *
11 * 1. Redistributions of source code must retain the
12 * above copyright notice, this list of conditions
13 * and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the
15 * above copyright notice, this list of conditions
16 * and the following disclaimer in the documentation
17 * and/or other materials provided with the
18 * distribution.
19 * 3. The name of the author may not be used to endorse
20 * or promote products derived from this software
21 * without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS''
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
25 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
29 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
30 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
34 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
36 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 */
38 /* }}} */
39
40 #ifndef REPLACE_HPP
41 #define REPLACE_HPP
42
43 #include "Parser.hpp"
44
45 #define $ new($pool)
46
47 #define $D(args...) \
48 ($ CYNumber(args))
49 #define $E(args...) \
50 ($ CYExpress(args))
51 #define $F(args...) \
52 ($ CYFunctionExpression(args))
53 #define $I(args...) \
54 ($ CYIdentifier(args))
55 #define $M(args...) \
56 ($ CYDirectMember(args))
57 #define $P(args...) \
58 ($ CYFunctionParameter(args))
59 #define $S(args...) \
60 ($ CYString(args))
61 #define $U \
62 $V($I("undefined"))
63 #define $V(name) \
64 ($ CYVariable(name))
65
66 #define $T(value) \
67 if (this == NULL) \
68 return value;
69 #define $$ \
70 CYStatements()
71
72 #define $P1(arg0, args...) \
73 $P($I(arg0), ##args)
74 #define $P2(arg0, arg1, args...) \
75 $P($I(arg0), $P1(arg1, ##args))
76 #define $P3(arg0, arg1, arg2, args...) \
77 $P($I(arg0), $P2(arg1, arg2, ##args))
78 #define $P4(arg0, arg1, arg2, arg3, args...) \
79 $P($I(arg0), $P3(arg1, arg2, arg3, ##args))
80 #define $P5(arg0, arg1, arg2, arg3, arg4, args...) \
81 $P($I(arg0), $P4(arg1, arg2, arg3, arg4, ##args))
82 #define $P6(arg0, arg1, arg2, arg3, arg4, arg5, args...) \
83 $P($I(arg0), $P5(arg1, arg2, arg3, arg4, arg5, ##args))
84
85 #define $C(args...) \
86 ($ CYCall(args))
87 #define $C_(args...) \
88 ($ CYArgument(args))
89 #define $N(args...) \
90 ($ cy::Syntax::New(args))
91
92 #define $C1_(arg0, args...) \
93 $C_(arg0, ##args)
94 #define $C2_(arg0, arg1, args...) \
95 $C_(arg0, $C1_(arg1, ##args))
96 #define $C3_(arg0, arg1, arg2, args...) \
97 $C_(arg0, $C2_(arg1, arg2, ##args))
98 #define $C4_(arg0, arg1, arg2, arg3, args...) \
99 $C_(arg0, $C3_(arg1, arg2, arg3, ##args))
100 #define $C5_(arg0, arg1, arg2, arg3, arg4, args...) \
101 $C_(arg0, $C4_(arg1, arg2, arg3, arg4, ##args))
102 #define $C6_(arg0, arg1, arg2, arg3, arg4, arg5, args...) \
103 $C_(arg0, $C5_(arg1, arg2, arg3, arg4, arg5, ##args))
104
105 #define $C0(func, args...) \
106 $C(func, ##args)
107 #define $C1(func, args...) \
108 $C(func, $C1_(args))
109 #define $C2(func, args...) \
110 $C(func, $C2_(args))
111 #define $C3(func, args...) \
112 $C(func, $C3_(args))
113 #define $C4(func, args...) \
114 $C(func, $C4_(args))
115 #define $C5(func, args...) \
116 $C(func, $C5_(args))
117
118 #define $N0(func, args...) \
119 $N(func, ##args)
120 #define $N1(func, args...) \
121 $N(func, $C1_(args))
122 #define $N2(func, args...) \
123 $N(func, $C2_(args))
124 #define $N3(func, args...) \
125 $N(func, $C3_(args))
126 #define $N4(func, args...) \
127 $N(func, $C4_(args))
128 #define $N5(func, args...) \
129 $N(func, $C5_(args))
130
131 #define $L(args...) \
132 $ CYDeclaration(args)
133 #define $L1(arg0) \
134 $ CYDeclarations(arg0)
135 #define $L2(arg0, args...) \
136 $ CYDeclarations(arg0, $L1(args))
137 #define $L3(arg0, args...) \
138 $ CYDeclarations(arg0, $L2(args))
139 #define $L4(arg0, args...) \
140 $ CYDeclarations(arg0, $L3(args))
141 #define $L5(arg0, args...) \
142 $ CYDeclarations(arg0, $L4(args))
143
144 #endif/*REPLACE_HPP*/