]> git.saurik.com Git - cycript.git/blob - Replace.hpp
Added support for octal literals.
[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 $ \
46 new(context.pool_)
47
48 #define $D(args...) \
49 ($ CYNumber(args))
50 #define $E(args...) \
51 ($ CYExpress(args))
52 #define $F(args...) \
53 ($ CYFunctionExpression(args))
54 #define $I(args...) \
55 ($ CYIdentifier(args))
56 #define $M(args...) \
57 ($ CYDirectMember(args))
58 #define $P(args...) \
59 ($ CYFunctionParameter(args))
60 #define $S(args...) \
61 ($ CYString(args))
62 #define $U \
63 $V("undefined")
64 #define $V(name) \
65 ($ CYVariable($I(name)))
66
67 #define $T(value) \
68 if (this == NULL) \
69 return value;
70 #define $$ \
71 CYStatements()
72
73 #define $P1(arg0, args...) \
74 $P($I(arg0), ##args)
75 #define $P2(arg0, arg1, args...) \
76 $P($I(arg0), $P1(arg1, ##args))
77 #define $P3(arg0, arg1, arg2, args...) \
78 $P($I(arg0), $P2(arg1, arg2, ##args))
79 #define $P4(arg0, arg1, arg2, arg3, args...) \
80 $P($I(arg0), $P3(arg1, arg2, arg3, ##args))
81 #define $P5(arg0, arg1, arg2, arg3, arg4, args...) \
82 $P($I(arg0), $P4(arg1, arg2, arg3, arg4, ##args))
83 #define $P6(arg0, arg1, arg2, arg3, arg4, arg5, args...) \
84 $P($I(arg0), $P5(arg1, arg2, arg3, arg4, arg5, ##args))
85
86 #define $C(args...) \
87 ($ CYCall(args))
88 #define $C_(args...) \
89 ($ CYArgument(args))
90 #define $N(args...) \
91 ($ CYNew(args))
92
93 #define $C1_(arg0, args...) \
94 $C_(arg0, ##args)
95 #define $C2_(arg0, arg1, args...) \
96 $C_(arg0, $C1_(arg1, ##args))
97 #define $C3_(arg0, arg1, arg2, args...) \
98 $C_(arg0, $C2_(arg1, arg2, ##args))
99 #define $C4_(arg0, arg1, arg2, arg3, args...) \
100 $C_(arg0, $C3_(arg1, arg2, arg3, ##args))
101 #define $C5_(arg0, arg1, arg2, arg3, arg4, args...) \
102 $C_(arg0, $C4_(arg1, arg2, arg3, arg4, ##args))
103 #define $C6_(arg0, arg1, arg2, arg3, arg4, arg5, args...) \
104 $C_(arg0, $C5_(arg1, arg2, arg3, arg4, arg5, ##args))
105
106 #define $C0(func, args...) \
107 $C(func, ##args)
108 #define $C1(func, args...) \
109 $C(func, $C1_(args))
110 #define $C2(func, args...) \
111 $C(func, $C2_(args))
112 #define $C3(func, args...) \
113 $C(func, $C3_(args))
114 #define $C4(func, args...) \
115 $C(func, $C4_(args))
116 #define $C5(func, args...) \
117 $C(func, $C5_(args))
118
119 #define $N0(func, args...) \
120 $N(func, ##args)
121 #define $N1(func, args...) \
122 $N(func, $C1_(args))
123 #define $N2(func, args...) \
124 $N(func, $C2_(args))
125 #define $N3(func, args...) \
126 $N(func, $C3_(args))
127 #define $N4(func, args...) \
128 $N(func, $C4_(args))
129 #define $N5(func, args...) \
130 $N(func, $C5_(args))
131
132 #define $L(args...) \
133 $ CYDeclaration(args)
134 #define $L1(arg0) \
135 $ CYDeclarations(arg0)
136 #define $L2(arg0, args...) \
137 $ CYDeclarations(arg0, $L1(args))
138 #define $L3(arg0, args...) \
139 $ CYDeclarations(arg0, $L2(args))
140 #define $L4(arg0, args...) \
141 $ CYDeclarations(arg0, $L3(args))
142 #define $L5(arg0, args...) \
143 $ CYDeclarations(arg0, $L4(args))
144
145 #endif/*REPLACE_HPP*/