… | |
… | |
40 | GvNAME (sv) ? GvNAME (sv) : "<anonymous>")) |
40 | GvNAME (sv) ? GvNAME (sv) : "<anonymous>")) |
41 | |
41 | |
42 | MODULE = Devel::FindRef PACKAGE = Devel::FindRef |
42 | MODULE = Devel::FindRef PACKAGE = Devel::FindRef |
43 | |
43 | |
44 | PROTOTYPES: ENABLE |
44 | PROTOTYPES: ENABLE |
45 | |
|
|
46 | SV * |
|
|
47 | ptr2ref (UV ptr) |
|
|
48 | CODE: |
|
|
49 | RETVAL = newRV_inc (INT2PTR (SV *, ptr)); |
|
|
50 | OUTPUT: |
|
|
51 | RETVAL |
|
|
52 | |
|
|
53 | UV |
|
|
54 | ref2ptr (SV *rv) |
|
|
55 | CODE: |
|
|
56 | RETVAL = PTR2UV (SvRV (rv)); |
|
|
57 | OUTPUT: |
|
|
58 | RETVAL |
|
|
59 | |
45 | |
60 | void |
46 | void |
61 | find_ (SV *target) |
47 | find_ (SV *target) |
62 | PPCODE: |
48 | PPCODE: |
63 | { |
49 | { |
… | |
… | |
112 | mg = mg->mg_moremagic; |
98 | mg = mg->mg_moremagic; |
113 | } |
99 | } |
114 | } |
100 | } |
115 | } |
101 | } |
116 | |
102 | |
117 | if (SvROK (sv)) |
103 | if (SvROK (sv) && !SvWEAKREF (sv)) |
118 | { |
104 | { |
119 | if (sv != target && SvRV (sv) == targ && !SvWEAKREF (sv)) |
105 | if (sv != target && SvRV (sv) == targ && !SvWEAKREF (sv)) |
120 | res_pair ("referenced by"); |
106 | res_pair ("referenced by"); |
121 | } |
107 | } |
122 | else |
108 | else |
… | |
… | |
223 | EXTEND (SP, 2); |
209 | EXTEND (SP, 2); |
224 | PUSHs (sv_2mortal (newRV_noinc ((SV *)about))); |
210 | PUSHs (sv_2mortal (newRV_noinc ((SV *)about))); |
225 | PUSHs (sv_2mortal (newRV_noinc ((SV *)excl))); |
211 | PUSHs (sv_2mortal (newRV_noinc ((SV *)excl))); |
226 | } |
212 | } |
227 | |
213 | |
|
|
214 | SV * |
|
|
215 | ptr2ref (UV ptr) |
|
|
216 | CODE: |
|
|
217 | RETVAL = newRV_inc (INT2PTR (SV *, ptr)); |
|
|
218 | OUTPUT: |
|
|
219 | RETVAL |
|
|
220 | |
|
|
221 | UV |
|
|
222 | ref2ptr (SV *rv) |
|
|
223 | CODE: |
|
|
224 | RETVAL = PTR2UV (SvRV (rv)); |
|
|
225 | OUTPUT: |
|
|
226 | RETVAL |
|
|
227 | |
|
|
228 | U32 |
|
|
229 | _refcnt (SV *rv) |
|
|
230 | CODE: |
|
|
231 | RETVAL = SvREFCNT (SvRV (rv)); |
|
|
232 | OUTPUT: |
|
|
233 | RETVAL |