xref: /php-src/ext/spl/spl_iterators.h (revision 54047c10)
1 /*
2    +----------------------------------------------------------------------+
3    | Copyright (c) The PHP Group                                          |
4    +----------------------------------------------------------------------+
5    | This source file is subject to version 3.01 of the PHP license,      |
6    | that is bundled with this package in the file LICENSE, and is        |
7    | available through the world-wide-web at the following url:           |
8    | https://www.php.net/license/3_01.txt                                 |
9    | If you did not receive a copy of the PHP license and are unable to   |
10    | obtain it through the world-wide-web, please send a note to          |
11    | license@php.net so we can mail you a copy immediately.               |
12    +----------------------------------------------------------------------+
13    | Authors: Marcus Boerger <helly@php.net>                              |
14    +----------------------------------------------------------------------+
15  */
16 
17 #ifndef SPL_ITERATORS_H
18 #define SPL_ITERATORS_H
19 
20 #include "php.h"
21 
22 extern PHPAPI zend_class_entry *spl_ce_AppendIterator;
23 extern PHPAPI zend_class_entry *spl_ce_CachingIterator;
24 extern PHPAPI zend_class_entry *spl_ce_CallbackFilterIterator;
25 extern PHPAPI zend_class_entry *spl_ce_EmptyIterator;
26 extern PHPAPI zend_class_entry *spl_ce_FilterIterator;
27 extern PHPAPI zend_class_entry *spl_ce_InfiniteIterator;
28 extern PHPAPI zend_class_entry *spl_ce_IteratorIterator;
29 extern PHPAPI zend_class_entry *spl_ce_LimitIterator;
30 extern PHPAPI zend_class_entry *spl_ce_NoRewindIterator;
31 extern PHPAPI zend_class_entry *spl_ce_OuterIterator;
32 extern PHPAPI zend_class_entry *spl_ce_ParentIterator;
33 extern PHPAPI zend_class_entry *spl_ce_RecursiveCachingIterator;
34 extern PHPAPI zend_class_entry *spl_ce_RecursiveCallbackFilterIterator;
35 extern PHPAPI zend_class_entry *spl_ce_RecursiveFilterIterator;
36 extern PHPAPI zend_class_entry *spl_ce_RecursiveIterator;
37 extern PHPAPI zend_class_entry *spl_ce_RecursiveIteratorIterator;
38 extern PHPAPI zend_class_entry *spl_ce_RecursiveRegexIterator;
39 extern PHPAPI zend_class_entry *spl_ce_RecursiveTreeIterator;
40 extern PHPAPI zend_class_entry *spl_ce_RegexIterator;
41 extern PHPAPI zend_class_entry *spl_ce_SeekableIterator;
42 
43 PHP_MINIT_FUNCTION(spl_iterators);
44 
45 
46 typedef enum {
47 	RIT_LEAVES_ONLY = 0,
48 	RIT_SELF_FIRST  = 1,
49 	RIT_CHILD_FIRST = 2
50 } RecursiveIteratorMode;
51 
52 #define RIT_CATCH_GET_CHILD CIT_CATCH_GET_CHILD
53 
54 typedef enum {
55 	RTIT_BYPASS_CURRENT = 4,
56 	RTIT_BYPASS_KEY	    = 8
57 } RecursiveTreeIteratorFlags;
58 
59 typedef enum {
60 	DIT_Default = 0,
61 	DIT_FilterIterator = DIT_Default,
62 	DIT_RecursiveFilterIterator = DIT_Default,
63 	DIT_ParentIterator = DIT_Default,
64 	DIT_LimitIterator,
65 	DIT_CachingIterator,
66 	DIT_RecursiveCachingIterator,
67 	DIT_IteratorIterator,
68 	DIT_NoRewindIterator,
69 	DIT_InfiniteIterator,
70 	DIT_AppendIterator,
71 	DIT_RegexIterator,
72 	DIT_RecursiveRegexIterator,
73 	DIT_CallbackFilterIterator,
74 	DIT_RecursiveCallbackFilterIterator,
75 	DIT_Unknown = ~0
76 } dual_it_type;
77 
78 typedef enum {
79 	RIT_Default = 0,
80 	RIT_RecursiveIteratorIterator = RIT_Default,
81 	RIT_RecursiveTreeIterator,
82 	RIT_Unknow = ~0
83 } recursive_it_it_type;
84 
85 enum {
86 	/* public */
87 	CIT_CALL_TOSTRING        = 0x00000001,
88 	CIT_TOSTRING_USE_KEY     = 0x00000002,
89 	CIT_TOSTRING_USE_CURRENT = 0x00000004,
90 	CIT_TOSTRING_USE_INNER   = 0x00000008,
91 	CIT_CATCH_GET_CHILD      = 0x00000010,
92 	CIT_FULL_CACHE           = 0x00000100,
93 	CIT_PUBLIC               = 0x0000FFFF,
94 	/* private */
95 	CIT_VALID                = 0x00010000,
96 	CIT_HAS_CHILDREN         = 0x00020000
97 };
98 
99 enum {
100 	/* public */
101 	REGIT_USE_KEY            = 0x00000001,
102 	REGIT_INVERTED           = 0x00000002
103 };
104 
105 typedef enum {
106 	REGIT_MODE_MATCH,
107 	REGIT_MODE_GET_MATCH,
108 	REGIT_MODE_ALL_MATCHES,
109 	REGIT_MODE_SPLIT,
110 	REGIT_MODE_REPLACE,
111 	REGIT_MODE_MAX
112 } regex_mode;
113 
114 typedef int (*spl_iterator_apply_func_t)(zend_object_iterator *iter, void *puser);
115 
116 PHPAPI zend_result spl_iterator_apply(zval *obj, spl_iterator_apply_func_t apply_func, void *puser);
117 
118 #endif /* SPL_ITERATORS_H */
119