This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Document :shared and :unique in attributes.pm
[perl5.git] / ext / re / re.xs
1 #if defined(PERL_EXT_RE_DEBUG) && !defined(DEBUGGING)
2 #  define DEBUGGING
3 #endif
4
5 #define PERL_NO_GET_CONTEXT
6 #include "EXTERN.h"
7 #include "perl.h"
8 #include "XSUB.h"
9 #include "re_comp.h"
10
11
12 START_EXTERN_C
13
14 extern REGEXP*  my_re_compile (pTHX_ SV * const pattern, const U32 pm_flags);
15 extern REGEXP*  my_re_op_compile (pTHX_ SV ** const patternp, int pat_count,
16                     OP *expr, const regexp_engine* eng, REGEXP *VOL old_re,
17                      bool *is_bare_re, U32 rx_flags, U32 pm_flags);
18
19 extern I32      my_regexec (pTHX_ REGEXP * const prog, char* stringarg, char* strend,
20                             char* strbeg, I32 minend, SV* screamer,
21                             void* data, U32 flags);
22
23 extern char*    my_re_intuit_start (pTHX_ REGEXP * const prog, SV *sv, char *strpos,
24                                     char *strend, const U32 flags,
25                                     struct re_scream_pos_data_s *data);
26 extern SV*      my_re_intuit_string (pTHX_ REGEXP * const prog);
27
28 extern void     my_regfree (pTHX_ REGEXP * const r);
29
30 extern void     my_reg_numbered_buff_fetch(pTHX_ REGEXP * const rx, const I32 paren,
31                                            SV * const usesv);
32 extern void     my_reg_numbered_buff_store(pTHX_ REGEXP * const rx, const I32 paren,
33                                            SV const * const value);
34 extern I32      my_reg_numbered_buff_length(pTHX_ REGEXP * const rx,
35                                             const SV * const sv, const I32 paren);
36
37 extern SV*      my_reg_named_buff(pTHX_ REGEXP * const, SV * const, SV * const,
38                               const U32);
39 extern SV*      my_reg_named_buff_iter(pTHX_ REGEXP * const rx,
40                                    const SV * const lastkey, const U32 flags);
41
42 extern SV*      my_reg_qr_package(pTHX_ REGEXP * const rx);
43 #if defined(USE_ITHREADS)
44 extern void*    my_regdupe (pTHX_ REGEXP * const r, CLONE_PARAMS *param);
45 #endif
46
47 EXTERN_C const struct regexp_engine my_reg_engine;
48
49 END_EXTERN_C
50
51 const struct regexp_engine my_reg_engine = { 
52         my_re_compile, 
53         my_regexec, 
54         my_re_intuit_start, 
55         my_re_intuit_string, 
56         my_regfree, 
57         my_reg_numbered_buff_fetch,
58         my_reg_numbered_buff_store,
59         my_reg_numbered_buff_length,
60         my_reg_named_buff,
61         my_reg_named_buff_iter,
62         my_reg_qr_package,
63 #if defined(USE_ITHREADS)
64         my_regdupe,
65 #endif
66         my_re_op_compile,
67 };
68
69 MODULE = re     PACKAGE = re
70
71 void
72 install()
73     PPCODE:
74         PL_colorset = 0;        /* Allow reinspection of ENV. */
75         /* PL_debug |= DEBUG_r_FLAG; */
76         XPUSHs(sv_2mortal(newSViv(PTR2IV(&my_reg_engine))));
77
78 void
79 regmust(sv)
80     SV * sv
81 PROTOTYPE: $
82 PREINIT:
83     REGEXP *re;
84 PPCODE:
85 {
86     if ((re = SvRX(sv)) /* assign deliberate */
87        /* only for re engines we know about */
88        && (RX_ENGINE(re) == &my_reg_engine
89            || RX_ENGINE(re) == &PL_core_reg_engine))
90     {
91         SV *an = &PL_sv_no;
92         SV *fl = &PL_sv_no;
93         if (RX_ANCHORED_SUBSTR(re)) {
94             an = sv_2mortal(newSVsv(RX_ANCHORED_SUBSTR(re)));
95         } else if (RX_ANCHORED_UTF8(re)) {
96             an = sv_2mortal(newSVsv(RX_ANCHORED_UTF8(re)));
97         }
98         if (RX_FLOAT_SUBSTR(re)) {
99             fl = sv_2mortal(newSVsv(RX_FLOAT_SUBSTR(re)));
100         } else if (RX_FLOAT_UTF8(re)) {
101             fl = sv_2mortal(newSVsv(RX_FLOAT_UTF8(re)));
102         }
103         XPUSHs(an);
104         XPUSHs(fl);
105         XSRETURN(2);
106     }
107     XSRETURN_UNDEF;
108 }
109