… | |
… | |
35 | #include "rxvtutil.h" |
35 | #include "rxvtutil.h" |
36 | #include "rxvtperl.h" |
36 | #include "rxvtperl.h" |
37 | |
37 | |
38 | #include "perlxsi.c" |
38 | #include "perlxsi.c" |
39 | |
39 | |
|
|
40 | #undef LINENO |
|
|
41 | #define LINENO(n) MOD (THIS->term_start + int(n), THIS->total_rows) |
|
|
42 | #undef ROW |
|
|
43 | #define ROW(n) THIS->row_buf [LINENO (n)] |
|
|
44 | |
40 | ///////////////////////////////////////////////////////////////////////////// |
45 | ///////////////////////////////////////////////////////////////////////////// |
41 | |
46 | |
42 | static wchar_t * |
47 | static wchar_t * |
43 | sv2wcs (SV *sv) |
48 | sv2wcs (SV *sv) |
44 | { |
49 | { |
… | |
… | |
208 | } |
213 | } |
209 | |
214 | |
210 | bool |
215 | bool |
211 | rxvt_perl_interp::invoke (rxvt_term *term, hook_type htype, ...) |
216 | rxvt_perl_interp::invoke (rxvt_term *term, hook_type htype, ...) |
212 | { |
217 | { |
213 | if (!perl) |
218 | if (!perl |
|
|
219 | || (!should_invoke [htype] && htype != HOOK_INIT && htype != HOOK_DESTROY)) |
214 | return false; |
220 | return false; |
215 | |
221 | |
216 | if (htype == HOOK_INIT) // first hook ever called |
222 | if (htype == HOOK_INIT) // first hook ever called |
217 | term->self = (void *)newSVptr ((void *)term, "urxvt::term"); |
223 | term->self = (void *)newSVptr ((void *)term, "urxvt::term"); |
218 | else if (htype == HOOK_DESTROY) |
|
|
219 | { |
|
|
220 | // TODO: clear magic |
|
|
221 | hv_clear ((HV *)SvRV ((SV *)term->self)); |
|
|
222 | SvREFCNT_dec ((SV *)term->self); |
|
|
223 | } |
|
|
224 | |
224 | |
225 | if (!should_invoke [htype]) |
|
|
226 | return false; |
|
|
227 | |
|
|
228 | dSP; |
225 | dSP; |
229 | va_list ap; |
226 | va_list ap; |
230 | |
227 | |
231 | va_start (ap, htype); |
228 | va_start (ap, htype); |
232 | |
229 | |
… | |
… | |
249 | |
246 | |
250 | case DT_LONG: |
247 | case DT_LONG: |
251 | XPUSHs (sv_2mortal (newSViv (va_arg (ap, long)))); |
248 | XPUSHs (sv_2mortal (newSViv (va_arg (ap, long)))); |
252 | break; |
249 | break; |
253 | |
250 | |
|
|
251 | case DT_STRING: |
|
|
252 | XPUSHs (sv_2mortal (newSVpv (va_arg (ap, char *), 0))); |
|
|
253 | break; |
|
|
254 | |
254 | case DT_END: |
255 | case DT_END: |
255 | { |
256 | { |
256 | va_end (ap); |
257 | va_end (ap); |
257 | |
258 | |
258 | PUTBACK; |
259 | PUTBACK; |
… | |
… | |
270 | LEAVE; |
271 | LEAVE; |
271 | |
272 | |
272 | if (SvTRUE (ERRSV)) |
273 | if (SvTRUE (ERRSV)) |
273 | rxvt_warn ("perl hook %d evaluation error: %s", htype, SvPV_nolen (ERRSV)); |
274 | rxvt_warn ("perl hook %d evaluation error: %s", htype, SvPV_nolen (ERRSV)); |
274 | |
275 | |
|
|
276 | if (htype == HOOK_DESTROY) |
|
|
277 | { |
|
|
278 | // TODO: clear magic |
|
|
279 | hv_clear ((HV *)SvRV ((SV *)term->self)); |
|
|
280 | SvREFCNT_dec ((SV *)term->self); |
|
|
281 | } |
|
|
282 | |
275 | return count; |
283 | return count; |
276 | } |
284 | } |
277 | |
285 | |
278 | default: |
286 | default: |
279 | rxvt_fatal ("FATAL: unable to pass data type %d\n", dt); |
287 | rxvt_fatal ("FATAL: unable to pass data type %d\n", dt); |
… | |
… | |
288 | PROTOTYPES: ENABLE |
296 | PROTOTYPES: ENABLE |
289 | |
297 | |
290 | BOOT: |
298 | BOOT: |
291 | { |
299 | { |
292 | # define set_hookname(sym) av_store (hookname, PP_CONCAT(HOOK_, sym), newSVpv (PP_STRINGIFY(sym), 0)) |
300 | # define set_hookname(sym) av_store (hookname, PP_CONCAT(HOOK_, sym), newSVpv (PP_STRINGIFY(sym), 0)) |
|
|
301 | # define export_const(name) newCONSTSUB (gv_stashpv ("urxvt", 1), #name, newSViv (name)); |
293 | AV *hookname = get_av ("urxvt::HOOKNAME", 1); |
302 | AV *hookname = get_av ("urxvt::HOOKNAME", 1); |
294 | set_hookname (LOAD); |
|
|
295 | set_hookname (INIT); |
303 | set_hookname (INIT); |
296 | set_hookname (RESET); |
304 | set_hookname (RESET); |
297 | set_hookname (START); |
305 | set_hookname (START); |
298 | set_hookname (DESTROY); |
306 | set_hookname (DESTROY); |
299 | set_hookname (SEL_BEGIN); |
307 | set_hookname (SEL_BEGIN); |
… | |
… | |
305 | set_hookname (VIEW_CHANGE); |
313 | set_hookname (VIEW_CHANGE); |
306 | set_hookname (SCROLL_BACK); |
314 | set_hookname (SCROLL_BACK); |
307 | set_hookname (TTY_ACTIVITY); |
315 | set_hookname (TTY_ACTIVITY); |
308 | set_hookname (REFRESH_BEGIN); |
316 | set_hookname (REFRESH_BEGIN); |
309 | set_hookname (REFRESH_END); |
317 | set_hookname (REFRESH_END); |
|
|
318 | set_hookname (KEYBOARD_COMMAND); |
|
|
319 | |
|
|
320 | export_const (DEFAULT_RSTYLE); |
|
|
321 | export_const (OVERLAY_RSTYLE); |
|
|
322 | export_const (RS_Bold); |
|
|
323 | export_const (RS_Italic); |
|
|
324 | export_const (RS_Blink); |
|
|
325 | export_const (RS_RVid); |
|
|
326 | export_const (RS_Uline); |
310 | |
327 | |
311 | sv_setpv (get_sv ("urxvt::LIBDIR", 1), LIBDIR); |
328 | sv_setpv (get_sv ("urxvt::LIBDIR", 1), LIBDIR); |
312 | } |
329 | } |
313 | |
330 | |
314 | void |
331 | void |
… | |
… | |
329 | NV |
346 | NV |
330 | NOW () |
347 | NOW () |
331 | CODE: |
348 | CODE: |
332 | RETVAL = NOW; |
349 | RETVAL = NOW; |
333 | OUTPUT: |
350 | OUTPUT: |
|
|
351 | RETVAL |
|
|
352 | |
|
|
353 | int |
|
|
354 | GET_BASEFG (int rend) |
|
|
355 | CODE: |
|
|
356 | RETVAL = GET_BASEFG (rend); |
|
|
357 | OUTPUT: |
|
|
358 | RETVAL |
|
|
359 | |
|
|
360 | int |
|
|
361 | GET_BASEBG (int rend) |
|
|
362 | CODE: |
|
|
363 | RETVAL = GET_BASEBG (rend); |
|
|
364 | OUTPUT: |
|
|
365 | RETVAL |
|
|
366 | |
|
|
367 | int |
|
|
368 | SET_FGCOLOR (int rend, int color) |
|
|
369 | CODE: |
|
|
370 | RETVAL = SET_FGCOLOR (rend, color); |
|
|
371 | OUTPUT: |
|
|
372 | RETVAL |
|
|
373 | |
|
|
374 | int |
|
|
375 | SET_BGCOLOR (int rend, int color) |
|
|
376 | CODE: |
|
|
377 | RETVAL = SET_BGCOLOR (rend, color); |
|
|
378 | OUTPUT: |
334 | RETVAL |
379 | RETVAL |
335 | |
380 | |
336 | MODULE = urxvt PACKAGE = urxvt::term |
381 | MODULE = urxvt PACKAGE = urxvt::term |
337 | |
382 | |
338 | int |
383 | int |
… | |
… | |
386 | SvUTF8_on (RETVAL); |
431 | SvUTF8_on (RETVAL); |
387 | free (str); |
432 | free (str); |
388 | } |
433 | } |
389 | OUTPUT: |
434 | OUTPUT: |
390 | RETVAL |
435 | RETVAL |
|
|
436 | |
|
|
437 | int |
|
|
438 | rxvt_term::nsaved () |
|
|
439 | CODE: |
|
|
440 | RETVAL = THIS->nsaved; |
|
|
441 | OUTPUT: |
|
|
442 | RETVAL |
|
|
443 | |
|
|
444 | int |
|
|
445 | rxvt_term::view_start (int newval = -1) |
|
|
446 | CODE: |
|
|
447 | { |
|
|
448 | RETVAL = THIS->view_start; |
|
|
449 | |
|
|
450 | if (newval >= 0) |
|
|
451 | { |
|
|
452 | THIS->view_start = min (newval, THIS->nsaved); |
|
|
453 | THIS->scr_changeview (RETVAL); |
|
|
454 | } |
|
|
455 | } |
|
|
456 | OUTPUT: |
|
|
457 | RETVAL |
|
|
458 | |
|
|
459 | int |
|
|
460 | rxvt_term::nrow () |
|
|
461 | CODE: |
|
|
462 | RETVAL = THIS->nrow; |
|
|
463 | OUTPUT: |
|
|
464 | RETVAL |
|
|
465 | |
|
|
466 | int |
|
|
467 | rxvt_term::ncol () |
|
|
468 | CODE: |
|
|
469 | RETVAL = THIS->ncol; |
|
|
470 | OUTPUT: |
|
|
471 | RETVAL |
|
|
472 | |
|
|
473 | void |
|
|
474 | rxvt_term::want_refresh () |
|
|
475 | CODE: |
|
|
476 | THIS->want_refresh = 1; |
|
|
477 | |
|
|
478 | void |
|
|
479 | rxvt_term::ROW_t (int row_number, SV *new_text = 0, int start_col = 0) |
|
|
480 | PPCODE: |
|
|
481 | { |
|
|
482 | if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) |
|
|
483 | croak ("row_number number of out range"); |
|
|
484 | |
|
|
485 | line_t &l = ROW(row_number); |
|
|
486 | |
|
|
487 | if (GIMME_V != G_VOID) |
|
|
488 | { |
|
|
489 | wchar_t *wstr = new wchar_t [THIS->ncol]; |
|
|
490 | |
|
|
491 | for (int col = 0; col <THIS->ncol; col++) |
|
|
492 | wstr [col] = l.t [col]; |
|
|
493 | |
|
|
494 | char *str = rxvt_wcstoutf8 (wstr, THIS->ncol); |
|
|
495 | free (wstr); |
|
|
496 | |
|
|
497 | SV *sv = newSVpv (str, 0); |
|
|
498 | SvUTF8_on (sv); |
|
|
499 | XPUSHs (sv_2mortal (sv)); |
|
|
500 | free (str); |
|
|
501 | } |
|
|
502 | |
|
|
503 | if (new_text) |
|
|
504 | { |
|
|
505 | STRLEN slen; |
|
|
506 | char *str = SvPVutf8 (new_text, slen); |
|
|
507 | wchar_t *wstr = rxvt_utf8towcs (str, slen); |
|
|
508 | |
|
|
509 | int len = wcslen (wstr); |
|
|
510 | |
|
|
511 | if (!IN_RANGE_INC (start_col, 0, THIS->ncol - len)) |
|
|
512 | { |
|
|
513 | free (wstr); |
|
|
514 | croak ("new_text extends beyond horizontal margins"); |
|
|
515 | } |
|
|
516 | |
|
|
517 | for (int col = start_col; col < start_col + len; col++) |
|
|
518 | { |
|
|
519 | l.t [col] = wstr [col - start_col]; |
|
|
520 | l.r [col] = SET_FONT (l.r [col], THIS->fontset [GET_STYLE (l.r [col])]->find_font (l.t [col])); |
|
|
521 | } |
|
|
522 | |
|
|
523 | free (wstr); |
|
|
524 | } |
|
|
525 | } |
|
|
526 | |
|
|
527 | void |
|
|
528 | rxvt_term::ROW_r (int row_number, SV *new_rend = 0, int start_col = 0) |
|
|
529 | PPCODE: |
|
|
530 | { |
|
|
531 | if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) |
|
|
532 | croak ("row_number number of out range"); |
|
|
533 | |
|
|
534 | line_t &l = ROW(row_number); |
|
|
535 | |
|
|
536 | if (GIMME_V != G_VOID) |
|
|
537 | { |
|
|
538 | AV *av = newAV (); |
|
|
539 | |
|
|
540 | av_extend (av, THIS->ncol - 1); |
|
|
541 | for (int col = 0; col < THIS->ncol; col++) |
|
|
542 | av_store (av, col, newSViv (l.r [col])); |
|
|
543 | |
|
|
544 | XPUSHs (sv_2mortal (newRV_noinc ((SV *)av))); |
|
|
545 | } |
|
|
546 | |
|
|
547 | if (new_rend) |
|
|
548 | { |
|
|
549 | if (!SvROK (new_rend) || SvTYPE (SvRV (new_rend)) != SVt_PVAV) |
|
|
550 | croak ("new_rend must be arrayref"); |
|
|
551 | |
|
|
552 | AV *av = (AV *)SvRV (new_rend); |
|
|
553 | int len = av_len (av) + 1; |
|
|
554 | |
|
|
555 | if (!IN_RANGE_INC (start_col, 0, THIS->ncol - len)) |
|
|
556 | croak ("new_rend array extends beyond horizontal margins"); |
|
|
557 | |
|
|
558 | for (int col = start_col; col < start_col + len; col++) |
|
|
559 | { |
|
|
560 | rend_t r = SvIV (*av_fetch (av, col - start_col, 1)) & ~RS_fontMask; |
|
|
561 | |
|
|
562 | l.r [col] = SET_FONT (r, THIS->fontset [GET_STYLE (r)]->find_font (l.t [col])); |
|
|
563 | } |
|
|
564 | } |
|
|
565 | } |
|
|
566 | |
|
|
567 | int |
|
|
568 | rxvt_term::ROW_l (int row_number, int new_length = -2) |
|
|
569 | CODE: |
|
|
570 | { |
|
|
571 | if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) |
|
|
572 | croak ("row_number number of out range"); |
|
|
573 | |
|
|
574 | line_t &l = ROW(row_number); |
|
|
575 | RETVAL = l.l; |
|
|
576 | |
|
|
577 | if (new_length >= -1) |
|
|
578 | l.l = new_length; |
|
|
579 | } |
|
|
580 | OUTPUT: |
|
|
581 | RETVAL |
|
|
582 | |
|
|
583 | SV * |
|
|
584 | rxvt_term::special_encode (SV *str) |
|
|
585 | CODE: |
|
|
586 | abort ();//TODO |
|
|
587 | |
|
|
588 | SV * |
|
|
589 | rxvt_term::special_decode (SV *str) |
|
|
590 | CODE: |
|
|
591 | abort ();//TODO |
391 | |
592 | |
392 | void |
593 | void |
393 | rxvt_term::_resource (char *name, int index, SV *newval = 0) |
594 | rxvt_term::_resource (char *name, int index, SV *newval = 0) |
394 | PPCODE: |
595 | PPCODE: |
395 | { |
596 | { |