]> git.saurik.com Git - cycript.git/blame - List.hpp
Cycript's lexer does not need to be "interactive".
[cycript.git] / List.hpp
CommitLineData
da2af935 1/* Cycript - Optimizing JavaScript Compiler/Runtime
c15969fd 2 * Copyright (C) 2009-2013 Jay Freeman (saurik)
da2af935
JF
3*/
4
c15969fd 5/* GNU General Public License, Version 3 {{{ */
da2af935 6/*
c15969fd
JF
7 * Cycript is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published
9 * by the Free Software Foundation, either version 3 of the License,
10 * or (at your option) any later version.
da2af935 11 *
c15969fd
JF
12 * Cycript is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
da2af935 16 *
c15969fd 17 * You should have received a copy of the GNU General Public License
da2af935
JF
18 * along with Cycript. If not, see <http://www.gnu.org/licenses/>.
19**/
20/* }}} */
21
22#ifndef CYCRIPT_LIST_HPP
23#define CYCRIPT_LIST_HPP
24
25template <typename Type_>
26struct CYNext {
27 Type_ *next_;
28
29 CYNext() :
30 next_(NULL)
31 {
32 }
33
34 CYNext(Type_ *next) :
35 next_(next)
36 {
37 }
38
39 void SetNext(Type_ *next) {
40 next_ = next;
41 }
42};
43
44template <typename Type_>
bf45251b 45Type_ *&CYSetLast(Type_ *&list) {
da2af935 46 if (list == NULL)
abadba19 47 return list;
bf45251b
JF
48
49 Type_ *next(list);
50 while (next->next_ != NULL)
51 next = next->next_;
52 return next->next_;
53}
54
55template <typename Type_>
56Type_ *CYGetLast(Type_ *list) {
57 if (list == NULL)
58 return NULL;
59
60 Type_ *next(list);
61 while (next->next_ != NULL)
62 next = next->next_;
63 return next;
da2af935
JF
64}
65
66#define CYForEach(value, list) \
67 for (__typeof__(*list) *value(list); value != NULL; value = value->next_)
68
69#endif/*CYCRIPT_LIST_HPP*/