cc_runtime.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /* cc_runtime.h
  2. *
  3. * Copyright (C) 1999, 2000, 2001, 2004, 2006, 2008 by Larry Wall and others
  4. *
  5. * You may distribute under the terms of either the GNU General Public
  6. * License or the Artistic License, as specified in the README file.
  7. *
  8. */
  9. #define DOOP(ppname) PUTBACK; PL_op = ppname(aTHX); SPAGAIN
  10. #define CCPP(s) OP * s(pTHX)
  11. #define PP_LIST(g) do { \
  12. dMARK; \
  13. if (g != G_ARRAY) { \
  14. if (++MARK <= SP) \
  15. *MARK = *SP; \
  16. else \
  17. *MARK = &PL_sv_undef; \
  18. SP = MARK; \
  19. } \
  20. } while (0)
  21. #define MAYBE_TAINT_SASSIGN_SRC(sv) \
  22. if (PL_tainting && PL_tainted && (!SvGMAGICAL(left) || !SvSMAGICAL(left) || \
  23. !((mg=mg_find(left, 't')) && mg->mg_len & 1)))\
  24. TAINT_NOT
  25. #define PP_PREINC(sv) do { \
  26. if (SvIOK(sv)) { \
  27. ++SvIVX(sv); \
  28. SvFLAGS(sv) &= ~(SVf_NOK|SVf_POK|SVp_NOK|SVp_POK); \
  29. } \
  30. else \
  31. sv_inc(sv); \
  32. SvSETMAGIC(sv); \
  33. } while (0)
  34. #define PP_UNSTACK do { \
  35. TAINT_NOT; \
  36. PL_stack_sp = PL_stack_base + cxstack[cxstack_ix].blk_oldsp; \
  37. FREETMPS; \
  38. oldsave = PL_scopestack[PL_scopestack_ix - 1]; \
  39. LEAVE_SCOPE(oldsave); \
  40. SPAGAIN; \
  41. } while(0)
  42. /* Anyone using eval "" deserves this mess */
  43. #if PERL_VERSION > 9
  44. #define PP_EVAL(ppaddr, nxt) do { \
  45. dJMPENV; \
  46. int ret; \
  47. PUTBACK; \
  48. JMPENV_PUSH(ret); \
  49. switch (ret) { \
  50. case 0: \
  51. PL_op = ppaddr(aTHX); \
  52. cxstack[cxstack_ix].blk_eval.retop = Nullop; \
  53. if (PL_op != nxt) CALLRUNOPS(aTHX); \
  54. JMPENV_POP; \
  55. break; \
  56. case 1: JMPENV_POP; JMPENV_JUMP(1); \
  57. case 2: JMPENV_POP; JMPENV_JUMP(2); \
  58. case 3: \
  59. JMPENV_POP; \
  60. if (PL_restartop && PL_restartop != nxt) \
  61. JMPENV_JUMP(3); \
  62. } \
  63. PL_op = nxt; \
  64. SPAGAIN; \
  65. } while (0)
  66. #define PP_ENTERTRY(label) \
  67. STMT_START { \
  68. dJMPENV; \
  69. int ret; \
  70. JMPENV_PUSH(ret); \
  71. switch (ret) { \
  72. case 1: JMPENV_POP; JMPENV_JUMP(1);\
  73. case 2: JMPENV_POP; JMPENV_JUMP(2);\
  74. case 3: JMPENV_POP; SPAGAIN; goto label;\
  75. } \
  76. } STMT_END
  77. #else /* 5.6 and 5.8 */
  78. #define PP_EVAL(ppaddr, nxt) do { \
  79. dJMPENV; \
  80. int ret; \
  81. PUTBACK; \
  82. JMPENV_PUSH(ret); \
  83. switch (ret) { \
  84. case 0: \
  85. PL_op = ppaddr(aTHX); \
  86. PL_retstack[PL_retstack_ix - 1] = Nullop; \
  87. if (PL_op != nxt) CALLRUNOPS(); \
  88. JMPENV_POP; \
  89. break; \
  90. case 1: JMPENV_POP; JMPENV_JUMP(1); \
  91. case 2: JMPENV_POP; JMPENV_JUMP(2); \
  92. case 3: \
  93. JMPENV_POP; \
  94. if (PL_restartop && PL_restartop != nxt) \
  95. JMPENV_JUMP(3); \
  96. } \
  97. PL_op = nxt; \
  98. SPAGAIN; \
  99. } while (0)
  100. #define PP_ENTERTRY(jmpbuf,label) \
  101. STMT_START { \
  102. int ret; \
  103. JMPENV_PUSH_ENV(jmpbuf,ret); \
  104. switch (ret) { \
  105. case 1: JMPENV_POP_ENV(jmpbuf); JMPENV_JUMP(1);\
  106. case 2: JMPENV_POP_ENV(jmpbuf); JMPENV_JUMP(2);\
  107. case 3: JMPENV_POP_ENV(jmpbuf); SPAGAIN; goto label;\
  108. } \
  109. } STMT_END
  110. #endif
  111. #define PP_LEAVETRY \
  112. STMT_START{ PL_top_env=PL_top_env->je_prev; }STMT_END