… | |
… | |
21 | |
21 | |
22 | #ifndef SVs_PADSTALE |
22 | #ifndef SVs_PADSTALE |
23 | # define SVs_PADSTALE 0 |
23 | # define SVs_PADSTALE 0 |
24 | #endif |
24 | #endif |
25 | |
25 | |
26 | #ifdef WIN32 |
26 | #if defined(_WIN32) |
|
|
27 | # undef HAS_GETTIMEOFDAY |
27 | # undef setjmp |
28 | # undef setjmp |
28 | # undef longjmp |
29 | # undef longjmp |
29 | # undef _exit |
30 | # undef _exit |
30 | # define setjmp _setjmp /* deep magic */ |
31 | # define setjmp _setjmp /* deep magic */ |
31 | #else |
32 | #else |
… | |
… | |
313 | /* entersub is an UNOP, select a LISTOP... keep your fingers crossed */ |
314 | /* entersub is an UNOP, select a LISTOP... keep your fingers crossed */ |
314 | PL_op->op_flags |= OPf_STACKED; |
315 | PL_op->op_flags |= OPf_STACKED; |
315 | PL_op->op_private = 0; |
316 | PL_op->op_private = 0; |
316 | return PL_ppaddr [OP_ENTERSUB](aTHX); |
317 | return PL_ppaddr [OP_ENTERSUB](aTHX); |
317 | } |
318 | } |
|
|
319 | |
|
|
320 | /** time stuff **************************************************************/ |
|
|
321 | |
|
|
322 | #ifdef HAS_GETTIMEOFDAY |
|
|
323 | |
|
|
324 | static void |
|
|
325 | coro_u2time (pTHX_ UV ret[2]) |
|
|
326 | { |
|
|
327 | struct timeval tv; |
|
|
328 | gettimeofday (&tv, 0); |
|
|
329 | |
|
|
330 | ret [0] = tv.tv_sec; |
|
|
331 | ret [1] = tv.tv_usec; |
|
|
332 | } |
|
|
333 | |
|
|
334 | static double |
|
|
335 | coro_nvtime () |
|
|
336 | { |
|
|
337 | struct timeval tv; |
|
|
338 | gettimeofday (&tv, 0); |
|
|
339 | |
|
|
340 | return tv.tv_sec + tv.tv_usec * 1e-6; |
|
|
341 | } |
|
|
342 | |
|
|
343 | static void |
|
|
344 | time_init (pTHX) |
|
|
345 | { |
|
|
346 | nvtime = coro_nvtime; |
|
|
347 | u2time = coro_u2time; |
|
|
348 | } |
|
|
349 | |
|
|
350 | #else |
|
|
351 | |
|
|
352 | static void |
|
|
353 | time_init (pTHX) |
|
|
354 | { |
|
|
355 | SV **svp; |
|
|
356 | |
|
|
357 | require_pv ("Time/HiRes.pm"); |
|
|
358 | |
|
|
359 | svp = hv_fetch (PL_modglobal, "Time::NVtime", 12, 0); |
|
|
360 | |
|
|
361 | if (!svp) croak ("Time::HiRes is required, but missing."); |
|
|
362 | if (!SvIOK (*svp)) croak ("Time::NVtime isn't a function pointer"); |
|
|
363 | |
|
|
364 | nvtime = INT2PTR (double (*)(), SvIV (*svp)); |
|
|
365 | |
|
|
366 | svp = hv_fetch (PL_modglobal, "Time::U2time", 12, 0); |
|
|
367 | u2time = INT2PTR (void (*)(pTHX_ UV ret[2]), SvIV (*svp)); |
|
|
368 | } |
|
|
369 | |
|
|
370 | #endif |
318 | |
371 | |
319 | /** lowlevel stuff **********************************************************/ |
372 | /** lowlevel stuff **********************************************************/ |
320 | |
373 | |
321 | static SV * |
374 | static SV * |
322 | coro_get_sv (pTHX_ const char *name, int create) |
375 | coro_get_sv (pTHX_ const char *name, int create) |
… | |
… | |
3109 | coroapi.prepare_nop = prepare_nop; |
3162 | coroapi.prepare_nop = prepare_nop; |
3110 | coroapi.prepare_schedule = prepare_schedule; |
3163 | coroapi.prepare_schedule = prepare_schedule; |
3111 | coroapi.prepare_cede = prepare_cede; |
3164 | coroapi.prepare_cede = prepare_cede; |
3112 | coroapi.prepare_cede_notself = prepare_cede_notself; |
3165 | coroapi.prepare_cede_notself = prepare_cede_notself; |
3113 | |
3166 | |
3114 | { |
3167 | time_init (aTHX); |
3115 | SV **svp = hv_fetch (PL_modglobal, "Time::NVtime", 12, 0); |
|
|
3116 | |
|
|
3117 | if (!svp) croak ("Time::HiRes is required"); |
|
|
3118 | if (!SvIOK (*svp)) croak ("Time::NVtime isn't a function pointer"); |
|
|
3119 | |
|
|
3120 | nvtime = INT2PTR (double (*)(), SvIV (*svp)); |
|
|
3121 | |
|
|
3122 | svp = hv_fetch (PL_modglobal, "Time::U2time", 12, 0); |
|
|
3123 | u2time = INT2PTR (void (*)(pTHX_ UV ret[2]), SvIV (*svp)); |
|
|
3124 | } |
|
|
3125 | |
3168 | |
3126 | assert (("PRIO_NORMAL must be 0", !CORO_PRIO_NORMAL)); |
3169 | assert (("PRIO_NORMAL must be 0", !CORO_PRIO_NORMAL)); |
3127 | } |
3170 | } |
3128 | |
3171 | |
3129 | SV * |
3172 | SV * |
… | |
… | |
3351 | void |
3394 | void |
3352 | cancel (Coro::State self) |
3395 | cancel (Coro::State self) |
3353 | CODE: |
3396 | CODE: |
3354 | coro_state_destroy (aTHX_ self); |
3397 | coro_state_destroy (aTHX_ self); |
3355 | coro_call_on_destroy (aTHX_ self); /* actually only for Coro objects */ |
3398 | coro_call_on_destroy (aTHX_ self); /* actually only for Coro objects */ |
3356 | |
|
|
3357 | |
3399 | |
3358 | SV * |
3400 | SV * |
3359 | enable_times (int enabled = enable_times) |
3401 | enable_times (int enabled = enable_times) |
3360 | CODE: |
3402 | CODE: |
3361 | { |
3403 | { |