#arch := $(shell $(dpkg_architecture) -qDEB_HOST_ARCH 2>/dev/null)
#endif
-header := Cycript.tab.hh Parser.hpp Pooling.hpp Local.hpp cycript.hpp Internal.hpp Error.hpp String.hpp Exception.hpp Standard.hpp
+header := Cycript.tab.hh Parser.hpp Pooling.hpp List.hpp Local.hpp cycript.hpp Internal.hpp Error.hpp String.hpp Exception.hpp Standard.hpp
code :=
code += Replace.lo Output.lo
--- /dev/null
+/* Cycript - Optimizing JavaScript Compiler/Runtime
+ * Copyright (C) 2009-2010 Jay Freeman (saurik)
+*/
+
+/* GNU Lesser General Public License, Version 3 {{{ */
+/*
+ * Cycript is free software: you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation, either version 3 of the License, or (at your
+ * option) any later version.
+ *
+ * Cycript 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 Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with Cycript. If not, see <http://www.gnu.org/licenses/>.
+**/
+/* }}} */
+
+#ifndef CYCRIPT_LIST_HPP
+#define CYCRIPT_LIST_HPP
+
+template <typename Type_>
+struct CYNext {
+ Type_ *next_;
+
+ CYNext() :
+ next_(NULL)
+ {
+ }
+
+ CYNext(Type_ *next) :
+ next_(next)
+ {
+ }
+
+ void SetNext(Type_ *next) {
+ next_ = next;
+ }
+};
+
+template <typename Type_>
+void CYSetLast(Type_ *&list, Type_ *item) {
+ if (list == NULL)
+ list = item;
+ else {
+ Type_ *next(list);
+ while (next->next_ != NULL)
+ next = next->next_;
+ next->next_ = item;
+ }
+}
+
+#define CYForEach(value, list) \
+ for (__typeof__(*list) *value(list); value != NULL; value = value->next_)
+
+#endif/*CYCRIPT_LIST_HPP*/
#include <cstdlib>
#include "location.hh"
+
+#include "List.hpp"
#include "Pooling.hpp"
#include "Options.hpp"
class CYContext;
-template <typename Type_>
-struct CYNext {
- Type_ *next_;
-
- CYNext() :
- next_(NULL)
- {
- }
-
- CYNext(Type_ *next) :
- next_(next)
- {
- }
-
- void SetNext(Type_ *next) {
- next_ = next;
- }
-};
-
-template <typename Type_>
-void CYSetLast(Type_ *&list, Type_ *item) {
- if (list == NULL)
- list = item;
- else {
- Type_ *next(list);
- while (next->next_ != NULL)
- next = next->next_;
- next->next_ = item;
- }
-}
-
-#define CYForEach(value, list) \
- for (__typeof__(*list) *value(list); value != NULL; value = value->next_)
-
struct CYThing {
virtual ~CYThing() {
}
arch := $(shell $(dpkg_architecture) -qDEB_HOST_ARCH 2>/dev/null)
endif
-header := Cycript.tab.hh Parser.hpp Pooling.hpp Local.hpp cycript.hpp Internal.hpp Error.hpp String.hpp Exception.hpp Standard.hpp
+header := Cycript.tab.hh Parser.hpp Pooling.hpp List.hpp Local.hpp cycript.hpp Internal.hpp Error.hpp String.hpp Exception.hpp Standard.hpp
code :=
code += Replace.o Output.o