]> git.saurik.com Git - cycript.git/blobdiff - Replace.hpp
Improve accuracy of JNI local references tracking.
[cycript.git] / Replace.hpp
index de3c33a57c31ae7aeaba998da679fe115c936629..117b23ef0df3a0c668138efa104957333ff9f6c2 100644 (file)
@@ -1,10 +1,30 @@
-#ifndef REPLACE_HPP
-#define REPLACE_HPP
+/* Cycript - The Truly Universal Scripting Language
+ * Copyright (C) 2009-2016  Jay Freeman (saurik)
+*/
 
-#include "Parser.hpp"
+/* GNU Affero General Public License, Version 3 {{{ */
+/*
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
 
-#define $ \
-    new(context.pool_)
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+**/
+/* }}} */
+
+#ifndef CYCRIPT_REPLACE_HPP
+#define CYCRIPT_REPLACE_HPP
+
+#include "Syntax.hpp"
+
+#define $ new($pool)
 
 #define $D(args...) \
     ($ CYNumber(args))
     ($ CYFunctionParameter(args))
 #define $S(args...) \
     ($ CYString(args))
+#define $U \
+    $V($I("undefined"))
 #define $V(name) \
-    ($ CYVariable($I(name)))
+    ($ CYVariable(name))
 
 #define $T(value) \
     if (this == NULL) \
     CYStatements()
 
 #define $P1(arg0, args...) \
-    $P($I(arg0), ##args)
+    $P(arg0, ##args)
 #define $P2(arg0, arg1, args...) \
-    $P($I(arg0), $P1(arg1, ##args))
+    $P(arg0, $P1(arg1, ##args))
 #define $P3(arg0, arg1, arg2, args...) \
-    $P($I(arg0), $P2(arg1, arg2, ##args))
+    $P(arg0, $P2(arg1, arg2, ##args))
 #define $P4(arg0, arg1, arg2, arg3, args...) \
-    $P($I(arg0), $P3(arg1, arg2, arg3, ##args))
+    $P(arg0, $P3(arg1, arg2, arg3, ##args))
 #define $P5(arg0, arg1, arg2, arg3, arg4, args...) \
-    $P($I(arg0), $P4(arg1, arg2, arg3, arg4, ##args))
+    $P(arg0, $P4(arg1, arg2, arg3, arg4, ##args))
 #define $P6(arg0, arg1, arg2, arg3, arg4, arg5, args...) \
-    $P($I(arg0), $P5(arg1, arg2, arg3, arg4, arg5, ##args))
+    $P(arg0, $P5(arg1, arg2, arg3, arg4, arg5, ##args))
 
 #define $C(args...) \
     ($ CYCall(args))
 #define $C_(args...) \
     ($ CYArgument(args))
 #define $N(args...) \
-    ($ CYNew(args))
+    ($ cy::Syntax::New(args))
 
 #define $C1_(arg0, args...) \
     $C_(arg0, ##args)
 #define $N5(func, args...) \
     $N(func, $C5_(args))
 
-#endif/*REPLACE_HPP*/
+#define $B(args...) \
+    $ CYBinding(args)
+#define $B1(arg0) \
+    $ CYBindings(arg0)
+#define $B2(arg0, args...) \
+    $ CYBindings(arg0, $B1(args))
+#define $B3(arg0, args...) \
+    $ CYBindings(arg0, $B2(args))
+#define $B4(arg0, args...) \
+    $ CYBindings(arg0, $B3(args))
+#define $B5(arg0, args...) \
+    $ CYBindings(arg0, $B4(args))
+
+#endif/*CYCRIPT_REPLACE_HPP*/