cc_runtime.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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. int ret; \
  46. PUTBACK; \
  47. JMPENV_PUSH(ret); \
  48. switch (ret) { \
  49. case 0: \
  50. PL_op = ppaddr(aTHX); \
  51. cxstack[cxstack_ix].blk_eval.retop = Nullop; \
  52. if (PL_op != nxt) CALLRUNOPS(aTHX); \
  53. JMPENV_POP; \
  54. break; \
  55. case 1: JMPENV_POP; JMPENV_JUMP(1); \
  56. case 2: JMPENV_POP; JMPENV_JUMP(2); \
  57. case 3: \
  58. JMPENV_POP; \
  59. if (PL_restartop && PL_restartop != nxt) \
  60. JMPENV_JUMP(3); \
  61. } \
  62. PL_op = nxt; \
  63. SPAGAIN; \
  64. } while (0)
  65. #define PP_ENTERTRY(label) \
  66. STMT_START { \
  67. int ret; \
  68. JMPENV_PUSH(ret); \
  69. switch (ret) { \
  70. case 1: JMPENV_POP; JMPENV_JUMP(1);\
  71. case 2: JMPENV_POP; JMPENV_JUMP(2);\
  72. case 3: JMPENV_POP; SPAGAIN; goto label;\
  73. } \
  74. } STMT_END
  75. #else /* 5.6 and 5.8 */
  76. #define PP_EVAL(ppaddr, nxt) do { \
  77. dJMPENV; \
  78. int ret; \
  79. PUTBACK; \
  80. JMPENV_PUSH(ret); \
  81. switch (ret) { \
  82. case 0: \
  83. PL_op = ppaddr(aTHX); \
  84. PL_retstack[PL_retstack_ix - 1] = Nullop; \
  85. if (PL_op != nxt) CALLRUNOPS(); \
  86. JMPENV_POP; \
  87. break; \
  88. case 1: JMPENV_POP; JMPENV_JUMP(1); \
  89. case 2: JMPENV_POP; JMPENV_JUMP(2); \
  90. case 3: \
  91. JMPENV_POP; \
  92. if (PL_restartop && PL_restartop != nxt) \
  93. JMPENV_JUMP(3); \
  94. } \
  95. PL_op = nxt; \
  96. SPAGAIN; \
  97. } while (0)
  98. #define PP_ENTERTRY(jmpbuf,label) \
  99. STMT_START { \
  100. int ret; \
  101. JMPENV_PUSH_ENV(jmpbuf,ret); \
  102. switch (ret) { \
  103. case 1: JMPENV_POP_ENV(jmpbuf); JMPENV_JUMP(1);\
  104. case 2: JMPENV_POP_ENV(jmpbuf); JMPENV_JUMP(2);\
  105. case 3: JMPENV_POP_ENV(jmpbuf); SPAGAIN; goto label;\
  106. } \
  107. } STMT_END
  108. #endif
  109. #define PP_LEAVETRY \
  110. STMT_START { PL_top_env = PL_top_env->je_prev; } STMT_END