|
Packit |
7d6a7d |
################################################################################
|
|
Packit |
7d6a7d |
##
|
|
Packit |
7d6a7d |
## Version 3.x, Copyright (C) 2004-2013, Marcus Holland-Moritz.
|
|
Packit |
7d6a7d |
## Version 2.x, Copyright (C) 2001, Paul Marquess.
|
|
Packit |
7d6a7d |
## Version 1.x, Copyright (C) 1999, Kenneth Albanowski.
|
|
Packit |
7d6a7d |
##
|
|
Packit |
7d6a7d |
## This program is free software; you can redistribute it and/or
|
|
Packit |
7d6a7d |
## modify it under the same terms as Perl itself.
|
|
Packit |
7d6a7d |
##
|
|
Packit |
7d6a7d |
################################################################################
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=provides
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__
|
|
Packit |
7d6a7d |
PERL_UNUSED_DECL
|
|
Packit |
7d6a7d |
PERL_UNUSED_ARG
|
|
Packit |
7d6a7d |
PERL_UNUSED_VAR
|
|
Packit |
7d6a7d |
PERL_UNUSED_CONTEXT
|
|
Packit |
7d6a7d |
PERL_UNUSED_RESULT
|
|
Packit |
7d6a7d |
PERL_GCC_BRACE_GROUPS_FORBIDDEN
|
|
Packit |
7d6a7d |
PERL_USE_GCC_BRACE_GROUPS
|
|
Packit |
7d6a7d |
PERLIO_FUNCS_DECL
|
|
Packit |
7d6a7d |
PERLIO_FUNCS_CAST
|
|
Packit |
7d6a7d |
NVTYPE
|
|
Packit |
7d6a7d |
INT2PTR
|
|
Packit |
7d6a7d |
PTRV
|
|
Packit |
7d6a7d |
NUM2PTR
|
|
Packit |
7d6a7d |
PERL_HASH
|
|
Packit |
7d6a7d |
PTR2IV
|
|
Packit |
7d6a7d |
PTR2UV
|
|
Packit |
7d6a7d |
PTR2NV
|
|
Packit |
7d6a7d |
PTR2ul
|
|
Packit |
7d6a7d |
START_EXTERN_C
|
|
Packit |
7d6a7d |
END_EXTERN_C
|
|
Packit |
7d6a7d |
EXTERN_C
|
|
Packit |
7d6a7d |
STMT_START
|
|
Packit |
7d6a7d |
STMT_END
|
|
Packit |
7d6a7d |
UTF8_MAXBYTES
|
|
Packit |
7d6a7d |
WIDEST_UTYPE
|
|
Packit |
7d6a7d |
XSRETURN
|
|
Packit |
7d6a7d |
HeUTF8
|
|
Packit |
7d6a7d |
C_ARRAY_LENGTH
|
|
Packit |
7d6a7d |
C_ARRAY_END
|
|
Packit |
7d6a7d |
SvRX
|
|
Packit |
7d6a7d |
SvRXOK
|
|
Packit |
7d6a7d |
PERL_MAGIC_qr
|
|
Packit |
7d6a7d |
cBOOL
|
|
Packit |
7d6a7d |
OpHAS_SIBLING
|
|
Packit |
7d6a7d |
OpSIBLING
|
|
Packit |
7d6a7d |
OpMORESIB_set
|
|
Packit |
7d6a7d |
OpLASTSIB_set
|
|
Packit |
7d6a7d |
OpMAYBESIB_set
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=implementation
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ PERL_MAGIC_qr 'r'
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ cBOOL(cbool) ((cbool) ? (bool)1 : (bool)0)
|
|
Packit |
7d6a7d |
__UNDEFINED__ OpHAS_SIBLING(o) (cBOOL((o)->op_sibling))
|
|
Packit |
7d6a7d |
__UNDEFINED__ OpSIBLING(o) (0 + (o)->op_sibling)
|
|
Packit |
7d6a7d |
__UNDEFINED__ OpMORESIB_set(o, sib) ((o)->op_sibling = (sib))
|
|
Packit |
7d6a7d |
__UNDEFINED__ OpLASTSIB_set(o, parent) ((o)->op_sibling = NULL)
|
|
Packit |
7d6a7d |
__UNDEFINED__ OpMAYBESIB_set(o, sib, parent) ((o)->op_sibling = (sib))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef SvRX
|
|
Packit |
7d6a7d |
#if { NEED SvRX }
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void *
|
|
Packit |
7d6a7d |
SvRX(pTHX_ SV *rv)
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
if (SvROK(rv)) {
|
|
Packit |
7d6a7d |
SV *sv = SvRV(rv);
|
|
Packit |
7d6a7d |
if (SvMAGICAL(sv)) {
|
|
Packit |
7d6a7d |
MAGIC *mg = mg_find(sv, PERL_MAGIC_qr);
|
|
Packit |
7d6a7d |
if (mg && mg->mg_obj) {
|
|
Packit |
7d6a7d |
return mg->mg_obj;
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
return 0;
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ SvRXOK(sv) (!!SvRX(sv))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERL_UNUSED_DECL
|
|
Packit |
7d6a7d |
# ifdef HASATTRIBUTE
|
|
Packit |
7d6a7d |
# if (defined(__GNUC__) && defined(__cplusplus)) || defined(__INTEL_COMPILER)
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_DECL
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_DECL __attribute__((unused))
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_DECL
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERL_UNUSED_ARG
|
|
Packit |
7d6a7d |
# if defined(lint) && defined(S_SPLINT_S) /* www.splint.org */
|
|
Packit |
7d6a7d |
# include <note.h>
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_ARG(x) NOTE(ARGUNUSED(x))
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_ARG(x) ((void)x)
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERL_UNUSED_VAR
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_VAR(x) ((void)x)
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERL_UNUSED_CONTEXT
|
|
Packit |
7d6a7d |
# ifdef USE_ITHREADS
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_CONTEXT PERL_UNUSED_ARG(my_perl)
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_CONTEXT
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERL_UNUSED_RESULT
|
|
Packit |
7d6a7d |
# if defined(__GNUC__) && defined(HASATTRIBUTE_WARN_UNUSED_RESULT)
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_RESULT(v) STMT_START { __typeof__(v) z = (v); (void)sizeof(z); } STMT_END
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERL_UNUSED_RESULT(v) ((void)(v))
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ NOOP /*EMPTY*/(void)0
|
|
Packit |
7d6a7d |
__UNDEFINED__ dNOOP extern int /*@unused@*/ Perl___notused PERL_UNUSED_DECL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef NVTYPE
|
|
Packit |
7d6a7d |
# if defined(USE_LONG_DOUBLE) && defined(HAS_LONG_DOUBLE)
|
|
Packit |
7d6a7d |
# define NVTYPE long double
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define NVTYPE double
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
typedef NVTYPE NV;
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef INT2PTR
|
|
Packit |
7d6a7d |
# if (IVSIZE == PTRSIZE) && (UVSIZE == PTRSIZE)
|
|
Packit |
7d6a7d |
# define PTRV UV
|
|
Packit |
7d6a7d |
# define INT2PTR(any,d) (any)(d)
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# if PTRSIZE == LONGSIZE
|
|
Packit |
7d6a7d |
# define PTRV unsigned long
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PTRV unsigned
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
# define INT2PTR(any,d) (any)(PTRV)(d)
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PTR2ul
|
|
Packit |
7d6a7d |
# if PTRSIZE == LONGSIZE
|
|
Packit |
7d6a7d |
# define PTR2ul(p) (unsigned long)(p)
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PTR2ul(p) INT2PTR(unsigned long,p)
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ PTR2nat(p) (PTRV)(p)
|
|
Packit |
7d6a7d |
__UNDEFINED__ NUM2PTR(any,d) (any)PTR2nat(d)
|
|
Packit |
7d6a7d |
__UNDEFINED__ PTR2IV(p) INT2PTR(IV,p)
|
|
Packit |
7d6a7d |
__UNDEFINED__ PTR2UV(p) INT2PTR(UV,p)
|
|
Packit |
7d6a7d |
__UNDEFINED__ PTR2NV(p) NUM2PTR(NV,p)
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#undef START_EXTERN_C
|
|
Packit |
7d6a7d |
#undef END_EXTERN_C
|
|
Packit |
7d6a7d |
#undef EXTERN_C
|
|
Packit |
7d6a7d |
#ifdef __cplusplus
|
|
Packit |
7d6a7d |
# define START_EXTERN_C extern "C" {
|
|
Packit |
7d6a7d |
# define END_EXTERN_C }
|
|
Packit |
7d6a7d |
# define EXTERN_C extern "C"
|
|
Packit |
7d6a7d |
#else
|
|
Packit |
7d6a7d |
# define START_EXTERN_C
|
|
Packit |
7d6a7d |
# define END_EXTERN_C
|
|
Packit |
7d6a7d |
# define EXTERN_C extern
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#if defined(PERL_GCC_PEDANTIC)
|
|
Packit |
7d6a7d |
# ifndef PERL_GCC_BRACE_GROUPS_FORBIDDEN
|
|
Packit |
7d6a7d |
# define PERL_GCC_BRACE_GROUPS_FORBIDDEN
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#if defined(__GNUC__) && !defined(PERL_GCC_BRACE_GROUPS_FORBIDDEN) && !defined(__cplusplus)
|
|
Packit |
7d6a7d |
# ifndef PERL_USE_GCC_BRACE_GROUPS
|
|
Packit |
7d6a7d |
# define PERL_USE_GCC_BRACE_GROUPS
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#undef STMT_START
|
|
Packit |
7d6a7d |
#undef STMT_END
|
|
Packit |
7d6a7d |
#ifdef PERL_USE_GCC_BRACE_GROUPS
|
|
Packit |
7d6a7d |
# define STMT_START (void)( /* gcc supports ``({ STATEMENTS; })'' */
|
|
Packit |
7d6a7d |
# define STMT_END )
|
|
Packit |
7d6a7d |
#else
|
|
Packit |
7d6a7d |
# if defined(VOIDFLAGS) && (VOIDFLAGS) && (defined(sun) || defined(__sun__)) && !defined(__GNUC__)
|
|
Packit |
7d6a7d |
# define STMT_START if (1)
|
|
Packit |
7d6a7d |
# define STMT_END else (void)0
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define STMT_START do
|
|
Packit |
7d6a7d |
# define STMT_END while (0)
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ boolSV(b) ((b) ? &PL_sv_yes : &PL_sv_no)
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* DEFSV appears first in 5.004_56 */
|
|
Packit |
7d6a7d |
__UNDEFINED__ DEFSV GvSV(PL_defgv)
|
|
Packit |
7d6a7d |
__UNDEFINED__ SAVE_DEFSV SAVESPTR(GvSV(PL_defgv))
|
|
Packit |
7d6a7d |
__UNDEFINED__ DEFSV_set(sv) (DEFSV = (sv))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Older perls (<=5.003) lack AvFILLp */
|
|
Packit |
7d6a7d |
__UNDEFINED__ AvFILLp AvFILL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ ERRSV get_sv("@",FALSE)
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Hint: gv_stashpvn
|
|
Packit |
7d6a7d |
* This function's backport doesn't support the length parameter, but
|
|
Packit |
7d6a7d |
* rather ignores it. Portability can only be ensured if the length
|
|
Packit |
7d6a7d |
* parameter is used for speed reasons, but the length can always be
|
|
Packit |
7d6a7d |
* correctly computed from the string argument.
|
|
Packit |
7d6a7d |
*/
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ gv_stashpvn(str,len,create) gv_stashpv(str,create)
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Replace: 1 */
|
|
Packit |
7d6a7d |
__UNDEFINED__ get_cv perl_get_cv
|
|
Packit |
7d6a7d |
__UNDEFINED__ get_sv perl_get_sv
|
|
Packit |
7d6a7d |
__UNDEFINED__ get_av perl_get_av
|
|
Packit |
7d6a7d |
__UNDEFINED__ get_hv perl_get_hv
|
|
Packit |
7d6a7d |
/* Replace: 0 */
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ dUNDERBAR dNOOP
|
|
Packit |
7d6a7d |
__UNDEFINED__ UNDERBAR DEFSV
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ dAX I32 ax = MARK - PL_stack_base + 1
|
|
Packit |
7d6a7d |
__UNDEFINED__ dITEMS I32 items = SP - MARK
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ dXSTARG SV * targ = sv_newmortal()
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ dAXMARK I32 ax = POPMARK; \
|
|
Packit |
7d6a7d |
register SV ** const mark = PL_stack_base + ax++
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ XSprePUSH (sp = PL_stack_base + ax - 1)
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#if { VERSION < 5.005 }
|
|
Packit |
7d6a7d |
# undef XSRETURN
|
|
Packit |
7d6a7d |
# define XSRETURN(off) \
|
|
Packit |
7d6a7d |
STMT_START { \
|
|
Packit |
7d6a7d |
PL_stack_sp = PL_stack_base + ax + ((off) - 1); \
|
|
Packit |
7d6a7d |
return; \
|
|
Packit |
7d6a7d |
} STMT_END
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ XSPROTO(name) void name(pTHX_ CV* cv)
|
|
Packit |
7d6a7d |
__UNDEFINED__ SVfARG(p) ((void*)(p))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ PERL_ABS(x) ((x) < 0 ? -(x) : (x))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ dVAR dNOOP
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ SVf "_"
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ UTF8_MAXBYTES UTF8_MAXLEN
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ CPERLscope(x) x
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ PERL_HASH(hash,str,len) \
|
|
Packit |
7d6a7d |
STMT_START { \
|
|
Packit |
7d6a7d |
const char *s_PeRlHaSh = str; \
|
|
Packit |
7d6a7d |
I32 i_PeRlHaSh = len; \
|
|
Packit |
7d6a7d |
U32 hash_PeRlHaSh = 0; \
|
|
Packit |
7d6a7d |
while (i_PeRlHaSh--) \
|
|
Packit |
7d6a7d |
hash_PeRlHaSh = hash_PeRlHaSh * 33 + *s_PeRlHaSh++; \
|
|
Packit |
7d6a7d |
(hash) = hash_PeRlHaSh; \
|
|
Packit |
7d6a7d |
} STMT_END
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifndef PERLIO_FUNCS_DECL
|
|
Packit |
7d6a7d |
# ifdef PERLIO_FUNCS_CONST
|
|
Packit |
7d6a7d |
# define PERLIO_FUNCS_DECL(funcs) const PerlIO_funcs funcs
|
|
Packit |
7d6a7d |
# define PERLIO_FUNCS_CAST(funcs) (PerlIO_funcs*)(funcs)
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define PERLIO_FUNCS_DECL(funcs) PerlIO_funcs funcs
|
|
Packit |
7d6a7d |
# define PERLIO_FUNCS_CAST(funcs) (funcs)
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* provide these typedefs for older perls */
|
|
Packit |
7d6a7d |
#if { VERSION < 5.9.3 }
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
# ifdef ARGSproto
|
|
Packit |
7d6a7d |
typedef OP* (CPERLscope(*Perl_ppaddr_t))(ARGSproto);
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
typedef OP* (CPERLscope(*Perl_ppaddr_t))(pTHX);
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
typedef OP* (CPERLscope(*Perl_check_t)) (pTHX_ OP*);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ isPSXSPC(c) (isSPACE(c) || (c) == '\v')
|
|
Packit |
7d6a7d |
__UNDEFINED__ isBLANK(c) ((c) == ' ' || (c) == '\t')
|
|
Packit |
7d6a7d |
#ifdef EBCDIC
|
|
Packit |
7d6a7d |
__UNDEFINED__ isALNUMC(c) isalnum(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isASCII(c) isascii(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isCNTRL(c) iscntrl(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isGRAPH(c) isgraph(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isPRINT(c) isprint(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isPUNCT(c) ispunct(c)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isXDIGIT(c) isxdigit(c)
|
|
Packit |
7d6a7d |
#else
|
|
Packit |
7d6a7d |
# if { VERSION < 5.10.0 }
|
|
Packit |
7d6a7d |
/* Hint: isPRINT
|
|
Packit |
7d6a7d |
* The implementation in older perl versions includes all of the
|
|
Packit |
7d6a7d |
* isSPACE() characters, which is wrong. The version provided by
|
|
Packit |
7d6a7d |
* Devel::PPPort always overrides a present buggy version.
|
|
Packit |
7d6a7d |
*/
|
|
Packit |
7d6a7d |
# undef isPRINT
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#ifdef HAS_QUAD
|
|
Packit |
7d6a7d |
# ifdef U64TYPE
|
|
Packit |
7d6a7d |
# define WIDEST_UTYPE U64TYPE
|
|
Packit |
7d6a7d |
# else
|
|
Packit |
7d6a7d |
# define WIDEST_UTYPE Quad_t
|
|
Packit |
7d6a7d |
# endif
|
|
Packit |
7d6a7d |
#else
|
|
Packit |
7d6a7d |
# define WIDEST_UTYPE U32
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ isALNUMC(c) (isALPHA(c) || isDIGIT(c))
|
|
Packit |
7d6a7d |
__UNDEFINED__ isASCII(c) ((WIDEST_UTYPE) (c) <= 127)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isCNTRL(c) ((WIDEST_UTYPE) (c) < ' ' || (c) == 127)
|
|
Packit |
7d6a7d |
__UNDEFINED__ isGRAPH(c) (isALNUM(c) || isPUNCT(c))
|
|
Packit |
7d6a7d |
__UNDEFINED__ isPRINT(c) (((c) >= 32 && (c) < 127))
|
|
Packit |
7d6a7d |
__UNDEFINED__ isPUNCT(c) (((c) >= 33 && (c) <= 47) || ((c) >= 58 && (c) <= 64) || ((c) >= 91 && (c) <= 96) || ((c) >= 123 && (c) <= 126))
|
|
Packit |
7d6a7d |
__UNDEFINED__ isXDIGIT(c) (isDIGIT(c) || ((c) >= 'a' && (c) <= 'f') || ((c) >= 'A' && (c) <= 'F'))
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Until we figure out how to support this in older perls... */
|
|
Packit |
7d6a7d |
#if { VERSION >= 5.8.0 }
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ HeUTF8(he) ((HeKLEN(he) == HEf_SVKEY) ? \
|
|
Packit |
7d6a7d |
SvUTF8(HeKEY_sv(he)) : \
|
|
Packit |
7d6a7d |
(U32)HeKUTF8(he))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
__UNDEFINED__ C_ARRAY_LENGTH(a) (sizeof(a)/sizeof((a)[0]))
|
|
Packit |
7d6a7d |
__UNDEFINED__ C_ARRAY_END(a) ((a) + C_ARRAY_LENGTH(a))
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=xsmisc
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
typedef XSPROTO(XSPROTO_test_t);
|
|
Packit |
7d6a7d |
typedef XSPROTO_test_t *XSPROTO_test_t_ptr;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
XS(XS_Devel__PPPort_dXSTARG); /* prototype */
|
|
Packit |
7d6a7d |
XS(XS_Devel__PPPort_dXSTARG)
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
dXSARGS;
|
|
Packit |
7d6a7d |
dXSTARG;
|
|
Packit |
7d6a7d |
IV iv;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
PERL_UNUSED_VAR(cv);
|
|
Packit |
7d6a7d |
SP -= items;
|
|
Packit |
7d6a7d |
iv = SvIV(ST(0)) + 1;
|
|
Packit |
7d6a7d |
PUSHi(iv);
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
XS(XS_Devel__PPPort_dAXMARK); /* prototype */
|
|
Packit |
7d6a7d |
XS(XS_Devel__PPPort_dAXMARK)
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
dSP;
|
|
Packit |
7d6a7d |
dAXMARK;
|
|
Packit |
7d6a7d |
dITEMS;
|
|
Packit |
7d6a7d |
IV iv;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
PERL_UNUSED_VAR(cv);
|
|
Packit |
7d6a7d |
SP -= items;
|
|
Packit |
7d6a7d |
iv = SvIV(ST(0)) - 1;
|
|
Packit |
7d6a7d |
mPUSHi(iv);
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=xsinit
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#define NEED_SvRX
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=xsboot
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
XSPROTO_test_t_ptr p = &XS_Devel__PPPort_dXSTARG;
|
|
Packit |
7d6a7d |
newXS("Devel::PPPort::dXSTARG", *p, file);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
newXS("Devel::PPPort::dAXMARK", XS_Devel__PPPort_dAXMARK, file);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=xsubs
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
OpSIBLING_tests()
|
|
Packit |
7d6a7d |
PREINIT:
|
|
Packit |
7d6a7d |
OP *x;
|
|
Packit |
7d6a7d |
OP *kid;
|
|
Packit |
7d6a7d |
OP *lastkid;
|
|
Packit |
7d6a7d |
int count = 0;
|
|
Packit |
7d6a7d |
int failures = 0;
|
|
Packit |
7d6a7d |
int i;
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
x = newOP(OP_PUSHMARK, 0);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* No siblings yet! */
|
|
Packit |
7d6a7d |
if (OpHAS_SIBLING(x) || OpSIBLING(x)) {
|
|
Packit |
7d6a7d |
failures++; warn("Op should not have had a sib");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Add 2 siblings */
|
|
Packit |
7d6a7d |
kid = x;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
for (i = 0; i < 2; i++) {
|
|
Packit |
7d6a7d |
OP *newsib = newOP(OP_PUSHMARK, 0);
|
|
Packit |
7d6a7d |
OpMORESIB_set(kid, newsib);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
kid = OpSIBLING(kid);
|
|
Packit |
7d6a7d |
lastkid = kid;
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Should now have a sibling */
|
|
Packit |
7d6a7d |
if (! OpHAS_SIBLING(x) || ! OpSIBLING(x) ) {
|
|
Packit |
7d6a7d |
failures++; warn("Op should have had a sib after moresib_set");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Count the siblings */
|
|
Packit |
7d6a7d |
for (kid = OpSIBLING(x); kid; kid = OpSIBLING(kid)) {
|
|
Packit |
7d6a7d |
count++;
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if (count != 2) {
|
|
Packit |
7d6a7d |
failures++; warn("Kid had %d sibs, expected 2", count);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if (OpHAS_SIBLING(lastkid) || OpSIBLING(lastkid)) {
|
|
Packit |
7d6a7d |
failures++; warn("Last kid should not have a sib");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Really sets the parent, and says 'no more siblings' */
|
|
Packit |
7d6a7d |
OpLASTSIB_set(x, lastkid);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if (OpHAS_SIBLING(x) || OpSIBLING(x)) {
|
|
Packit |
7d6a7d |
failures++; warn("OpLASTSIB_set failed?");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Restore the kid */
|
|
Packit |
7d6a7d |
OpMORESIB_set(x, lastkid);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Try to remove it again */
|
|
Packit |
7d6a7d |
OpLASTSIB_set(x, NULL);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if (OpHAS_SIBLING(x) || OpSIBLING(x)) {
|
|
Packit |
7d6a7d |
failures++; warn("OpLASTSIB_set with NULL failed?");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
/* Try to restore with maybesib_set */
|
|
Packit |
7d6a7d |
OpMAYBESIB_set(x, lastkid, NULL);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if (! OpHAS_SIBLING(x) || ! OpSIBLING(x) ) {
|
|
Packit |
7d6a7d |
failures++; warn("Op should have had a sib after maybesibset");
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
RETVAL = failures;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
SvRXOK(sv)
|
|
Packit |
7d6a7d |
SV *sv
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = SvRXOK(sv);
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
ptrtests()
|
|
Packit |
7d6a7d |
PREINIT:
|
|
Packit |
7d6a7d |
int var, *p = &var;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = 0;
|
|
Packit |
7d6a7d |
RETVAL += PTR2nat(p) != 0 ? 1 : 0;
|
|
Packit |
7d6a7d |
RETVAL += PTR2ul(p) != 0UL ? 2 : 0;
|
|
Packit |
7d6a7d |
RETVAL += PTR2UV(p) != (UV) 0 ? 4 : 0;
|
|
Packit |
7d6a7d |
RETVAL += PTR2IV(p) != (IV) 0 ? 8 : 0;
|
|
Packit |
7d6a7d |
RETVAL += PTR2NV(p) != (NV) 0 ? 16 : 0;
|
|
Packit |
7d6a7d |
RETVAL += p > NUM2PTR(int *, 0) ? 32 : 0;
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
gv_stashpvn(name, create)
|
|
Packit |
7d6a7d |
char *name
|
|
Packit |
7d6a7d |
I32 create
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = gv_stashpvn(name, strlen(name), create) != NULL;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
get_sv(name, create)
|
|
Packit |
7d6a7d |
char *name
|
|
Packit |
7d6a7d |
I32 create
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = get_sv(name, create) != NULL;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
get_av(name, create)
|
|
Packit |
7d6a7d |
char *name
|
|
Packit |
7d6a7d |
I32 create
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = get_av(name, create) != NULL;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
get_hv(name, create)
|
|
Packit |
7d6a7d |
char *name
|
|
Packit |
7d6a7d |
I32 create
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = get_hv(name, create) != NULL;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
get_cv(name, create)
|
|
Packit |
7d6a7d |
char *name
|
|
Packit |
7d6a7d |
I32 create
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = get_cv(name, create) != NULL;
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
xsreturn(two)
|
|
Packit |
7d6a7d |
int two
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
mXPUSHp("test1", 5);
|
|
Packit |
7d6a7d |
if (two)
|
|
Packit |
7d6a7d |
mXPUSHp("test2", 5);
|
|
Packit |
7d6a7d |
if (two)
|
|
Packit |
7d6a7d |
XSRETURN(2);
|
|
Packit |
7d6a7d |
else
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
SV*
|
|
Packit |
7d6a7d |
boolSV(value)
|
|
Packit |
7d6a7d |
int value
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = newSVsv(boolSV(value));
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
SV*
|
|
Packit |
7d6a7d |
DEFSV()
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = newSVsv(DEFSV);
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
DEFSV_modify()
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
XPUSHs(sv_mortalcopy(DEFSV));
|
|
Packit |
7d6a7d |
ENTER;
|
|
Packit |
7d6a7d |
SAVE_DEFSV;
|
|
Packit |
7d6a7d |
DEFSV_set(newSVpvs("DEFSV"));
|
|
Packit |
7d6a7d |
XPUSHs(sv_mortalcopy(DEFSV));
|
|
Packit |
7d6a7d |
/* Yes, this leaks the above scalar; 5.005 with threads for some reason */
|
|
Packit |
7d6a7d |
/* frees it upon LEAVE, thus mortalizing it causes "attempt to free..." */
|
|
Packit |
7d6a7d |
/* sv_2mortal(DEFSV); */
|
|
Packit |
7d6a7d |
LEAVE;
|
|
Packit |
7d6a7d |
XPUSHs(sv_mortalcopy(DEFSV));
|
|
Packit |
7d6a7d |
XSRETURN(3);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
ERRSV()
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
RETVAL = SvTRUE(ERRSV);
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
SV*
|
|
Packit |
7d6a7d |
UNDERBAR()
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
dUNDERBAR;
|
|
Packit |
7d6a7d |
RETVAL = newSVsv(UNDERBAR);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
OUTPUT:
|
|
Packit |
7d6a7d |
RETVAL
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
prepush()
|
|
Packit |
7d6a7d |
CODE:
|
|
Packit |
7d6a7d |
{
|
|
Packit |
7d6a7d |
dXSTARG;
|
|
Packit |
7d6a7d |
XSprePUSH;
|
|
Packit |
7d6a7d |
PUSHi(42);
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
int
|
|
Packit |
7d6a7d |
PERL_ABS(a)
|
|
Packit |
7d6a7d |
int a
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
SVf(x)
|
|
Packit |
7d6a7d |
SV *x
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
#if { VERSION >= 5.004 }
|
|
Packit |
7d6a7d |
x = sv_2mortal(newSVpvf("[%"SVf"]", SVfARG(x)));
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
XPUSHs(x);
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
Perl_ppaddr_t(string)
|
|
Packit |
7d6a7d |
char *string
|
|
Packit |
7d6a7d |
PREINIT:
|
|
Packit |
7d6a7d |
Perl_ppaddr_t lower;
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
lower = PL_ppaddr[OP_LC];
|
|
Packit |
7d6a7d |
mXPUSHs(newSVpv(string, 0));
|
|
Packit |
7d6a7d |
PUTBACK;
|
|
Packit |
7d6a7d |
ENTER;
|
|
Packit |
7d6a7d |
(void)*(lower)(aTHXR);
|
|
Packit |
7d6a7d |
SPAGAIN;
|
|
Packit |
7d6a7d |
LEAVE;
|
|
Packit |
7d6a7d |
XSRETURN(1);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#if { VERSION >= 5.8.0 }
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
check_HeUTF8(utf8_key)
|
|
Packit |
7d6a7d |
SV *utf8_key;
|
|
Packit |
7d6a7d |
PREINIT:
|
|
Packit |
7d6a7d |
HV *hash;
|
|
Packit |
7d6a7d |
HE *ent;
|
|
Packit |
7d6a7d |
STRLEN klen;
|
|
Packit |
7d6a7d |
char *key;
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
hash = newHV();
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
key = SvPV(utf8_key, klen);
|
|
Packit |
7d6a7d |
if (SvUTF8(utf8_key)) klen *= -1;
|
|
Packit |
7d6a7d |
hv_store(hash, key, klen, newSVpvs("string"), 0);
|
|
Packit |
7d6a7d |
hv_iterinit(hash);
|
|
Packit |
7d6a7d |
ent = hv_iternext(hash);
|
|
Packit |
7d6a7d |
assert(ent);
|
|
Packit |
7d6a7d |
mXPUSHp((HeUTF8(ent) == 0 ? "norm" : "utf8"), 4);
|
|
Packit |
7d6a7d |
hv_undef(hash);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
#endif
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
void
|
|
Packit |
7d6a7d |
check_c_array()
|
|
Packit |
7d6a7d |
PREINIT:
|
|
Packit |
7d6a7d |
int x[] = { 10, 11, 12, 13 };
|
|
Packit |
7d6a7d |
PPCODE:
|
|
Packit |
7d6a7d |
mXPUSHi(C_ARRAY_LENGTH(x)); /* 4 */
|
|
Packit |
7d6a7d |
mXPUSHi(*(C_ARRAY_END(x)-1)); /* 13 */
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
=tests plan => 48
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
use vars qw($my_sv @my_av %my_hv);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::boolSV(1));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::boolSV(0));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
$_ = "Fred";
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::DEFSV(), "Fred");
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::UNDERBAR(), "Fred");
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if ($] >= 5.009002 && $] < 5.023 && $] < 5.023004) {
|
|
Packit |
7d6a7d |
eval q{
|
|
Packit |
7d6a7d |
no warnings "deprecated";
|
|
Packit |
7d6a7d |
no if $^V > v5.17.9, warnings => "experimental::lexical_topic";
|
|
Packit |
7d6a7d |
my $_ = "Tony";
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::DEFSV(), "Fred");
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::UNDERBAR(), "Tony");
|
|
Packit |
7d6a7d |
};
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
else {
|
|
Packit |
7d6a7d |
ok(1);
|
|
Packit |
7d6a7d |
ok(1);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
my @r = &Devel::PPPort::DEFSV_modify();
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(@r == 3);
|
|
Packit |
7d6a7d |
ok($r[0], 'Fred');
|
|
Packit |
7d6a7d |
ok($r[1], 'DEFSV');
|
|
Packit |
7d6a7d |
ok($r[2], 'Fred');
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::DEFSV(), "Fred");
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
eval { 1 };
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::ERRSV());
|
|
Packit |
7d6a7d |
eval { cannot_call_this_one() };
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::ERRSV());
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::gv_stashpvn('Devel::PPPort', 0));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::gv_stashpvn('does::not::exist', 0));
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::gv_stashpvn('does::not::exist', 1));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
$my_sv = 1;
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_sv('my_sv', 0));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::get_sv('not_my_sv', 0));
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_sv('not_my_sv', 1));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
@my_av = (1);
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_av('my_av', 0));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::get_av('not_my_av', 0));
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_av('not_my_av', 1));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
%my_hv = (a=>1);
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_hv('my_hv', 0));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::get_hv('not_my_hv', 0));
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_hv('not_my_hv', 1));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
sub my_cv { 1 };
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_cv('my_cv', 0));
|
|
Packit |
7d6a7d |
ok(!&Devel::PPPort::get_cv('not_my_cv', 0));
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::get_cv('not_my_cv', 1));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::dXSTARG(42), 43);
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::dAXMARK(4711), 4710);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::prepush(), 42);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(join(':', Devel::PPPort::xsreturn(0)), 'test1');
|
|
Packit |
7d6a7d |
ok(join(':', Devel::PPPort::xsreturn(1)), 'test1:test2');
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::PERL_ABS(42), 42);
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::PERL_ABS(-13), 13);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::SVf(42), $] >= 5.004 ? '[42]' : '42');
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::SVf('abc'), $] >= 5.004 ? '[abc]' : 'abc');
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::Perl_ppaddr_t("FOO"), "foo");
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::ptrtests(), 63);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::OpSIBLING_tests(), 0);
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if ($] >= 5.009000) {
|
|
Packit |
7d6a7d |
eval q{
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::check_HeUTF8("hello"), "norm");
|
|
Packit |
7d6a7d |
ok(&Devel::PPPort::check_HeUTF8("\N{U+263a}"), "utf8");
|
|
Packit |
7d6a7d |
};
|
|
Packit |
7d6a7d |
} else {
|
|
Packit |
7d6a7d |
ok(1, 1);
|
|
Packit |
7d6a7d |
ok(1, 1);
|
|
Packit |
7d6a7d |
}
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
@r = &Devel::PPPort::check_c_array();
|
|
Packit |
7d6a7d |
ok($r[0], 4);
|
|
Packit |
7d6a7d |
ok($r[1], "13");
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
ok(!Devel::PPPort::SvRXOK(""));
|
|
Packit |
7d6a7d |
ok(!Devel::PPPort::SvRXOK(bless [], "Regexp"));
|
|
Packit |
7d6a7d |
|
|
Packit |
7d6a7d |
if ($] < 5.005) {
|
|
Packit |
7d6a7d |
skip 'no qr// objects in this perl', 0;
|
|
Packit |
7d6a7d |
skip 'no qr// objects in this perl', 0;
|
|
Packit |
7d6a7d |
} else {
|
|
Packit |
7d6a7d |
my $qr = eval 'qr/./';
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::SvRXOK($qr));
|
|
Packit |
7d6a7d |
ok(Devel::PPPort::SvRXOK(bless $qr, "Surprise"));
|
|
Packit |
7d6a7d |
}
|