1 | /*----------------------------------------------------------------------* |
1 | /*----------------------------------------------------------------------* |
2 | * File: rxvtperl.xs |
2 | * File: rxvtperl.xs |
3 | *----------------------------------------------------------------------* |
3 | *----------------------------------------------------------------------* |
4 | * |
4 | * |
5 | * All portions of code are copyright by their respective author/s. |
5 | * All portions of code are copyright by their respective author/s. |
6 | * Copyright (c) 2005-2014,2011 Marc Lehmann <schmorp@schmorp.de> |
6 | * Copyright (c) 2005-2014 Marc Lehmann <schmorp@schmorp.de> |
7 | * |
7 | * |
8 | * This program is free software; you can redistribute it and/or modify |
8 | * This program is free software; you can redistribute it and/or modify |
9 | * it under the terms of the GNU General Public License as published by |
9 | * it under the terms of the GNU General Public License as published by |
10 | * the Free Software Foundation; either version 3 of the License, or |
10 | * the Free Software Foundation; either version 3 of the License, or |
11 | * (at your option) any later version. |
11 | * (at your option) any later version. |
… | |
… | |
82 | if (len != 1 && len != 3 && len != 4) |
82 | if (len != 1 && len != 3 && len != 4) |
83 | croak ("component colour array must have 1, 3 or 4 components,"); |
83 | croak ("component colour array must have 1, 3 or 4 components,"); |
84 | |
84 | |
85 | c.a = rgba::MAX_CC; |
85 | c.a = rgba::MAX_CC; |
86 | |
86 | |
87 | c.r = c.g = c.b = float_to_component (SvIV (*av_fetch (av, 0, 0))); |
87 | c.r = c.g = c.b = float_to_component (SvNV (*av_fetch (av, 0, 0))); |
88 | |
88 | |
89 | if (len >= 3) |
89 | if (len >= 3) |
90 | { |
90 | { |
91 | c.g = float_to_component (SvIV (*av_fetch (av, 1, 0))); |
91 | c.g = float_to_component (SvNV (*av_fetch (av, 1, 0))); |
92 | c.b = float_to_component (SvIV (*av_fetch (av, 2, 0))); |
92 | c.b = float_to_component (SvNV (*av_fetch (av, 2, 0))); |
93 | |
93 | |
94 | if (len >= 4) |
94 | if (len >= 4) |
95 | c.a = float_to_component (SvIV (*av_fetch (av, 3, 0))); |
95 | c.a = float_to_component (SvNV (*av_fetch (av, 3, 0))); |
96 | } |
96 | } |
97 | } |
97 | } |
98 | else if (s) |
98 | else if (s) |
99 | { |
99 | { |
100 | rxvt_color rc; |
100 | rxvt_color rc; |
… | |
… | |
291 | break; |
291 | break; |
292 | |
292 | |
293 | for (; i < AvFILL (overlay_av); i++) |
293 | for (; i < AvFILL (overlay_av); i++) |
294 | av_store (overlay_av, i, SvREFCNT_inc (*av_fetch (overlay_av, i + 1, 0))); |
294 | av_store (overlay_av, i, SvREFCNT_inc (*av_fetch (overlay_av, i + 1, 0))); |
295 | |
295 | |
296 | av_pop (overlay_av); |
296 | SvREFCNT_dec (av_pop (overlay_av)); |
297 | |
297 | |
298 | SvREFCNT_dec (overlay_av); |
298 | SvREFCNT_dec (overlay_av); |
299 | overlay_av = 0; |
299 | overlay_av = 0; |
300 | |
300 | |
301 | THIS->want_refresh = 1; |
301 | THIS->want_refresh = 1; |
… | |
… | |
370 | |
370 | |
371 | struct rxvt_perl_interp rxvt_perl; |
371 | struct rxvt_perl_interp rxvt_perl; |
372 | |
372 | |
373 | static PerlInterpreter *perl; |
373 | static PerlInterpreter *perl; |
374 | |
374 | |
|
|
375 | #if 0 /* we are not a library anymore, so doing this is just not worth it */ |
|
|
376 | /*THINK/TODO: this has the side effect of, of course, not calling destructors. */ |
|
|
377 | /* but therse are not guaranteed anyway... */ |
375 | rxvt_perl_interp::~rxvt_perl_interp () |
378 | rxvt_perl_interp::~rxvt_perl_interp () |
376 | { |
379 | { |
377 | if (perl) |
380 | if (perl) |
378 | { |
381 | { |
|
|
382 | localise_env set_environ (perl_environ); |
379 | perl_destruct (perl); |
383 | perl_destruct (perl); |
380 | perl_free (perl); |
384 | perl_free (perl); |
381 | PERL_SYS_TERM (); |
385 | PERL_SYS_TERM (); |
382 | } |
386 | } |
383 | } |
387 | } |
|
|
388 | #endif |
384 | |
389 | |
385 | void |
390 | void |
386 | rxvt_perl_interp::init () |
391 | rxvt_perl_interp::init () |
387 | { |
392 | { |
388 | if (!perl) |
393 | if (!perl) |
… | |
… | |
391 | |
396 | |
392 | { |
397 | { |
393 | perl_environ = rxvt_environ; |
398 | perl_environ = rxvt_environ; |
394 | localise_env set_environ (perl_environ); |
399 | localise_env set_environ (perl_environ); |
395 | |
400 | |
396 | char *args[] = { |
401 | const char *args[] = { |
397 | "", |
402 | "", |
398 | "-e" |
403 | "-e" |
399 | "BEGIN {" |
404 | "BEGIN {" |
400 | " urxvt->bootstrap;" |
405 | " urxvt->bootstrap;" |
401 | " unshift @INC, '" LIBDIR "';" |
406 | " unshift @INC, '" LIBDIR "';" |
402 | "}" |
407 | "}" |
403 | "" |
408 | "" |
404 | "use urxvt;" |
409 | "use urxvt;", |
|
|
410 | 0 |
405 | }; |
411 | }; |
406 | int argc = ecb_array_length (args); |
412 | int argc = ecb_array_length (args) - 1; |
407 | char **argv = args; |
413 | char **argv = (char **)args; |
408 | |
414 | |
409 | PERL_SYS_INIT3 (&argc, &argv, &environ); |
415 | PERL_SYS_INIT3 (&argc, &argv, &environ); |
410 | perl = perl_alloc (); |
416 | perl = perl_alloc (); |
411 | perl_construct (perl); |
417 | perl_construct (perl); |
412 | |
418 | |
… | |
… | |
523 | THIS->perl.grabtime = 0; |
529 | THIS->perl.grabtime = 0; |
524 | } |
530 | } |
525 | } |
531 | } |
526 | |
532 | |
527 | bool |
533 | bool |
528 | rxvt_perl_interp::invoke (rxvt_term *term, hook_type htype, ...) |
534 | rxvt_perl_interp::invoke (rxvt_term *term, int htype, ...) |
529 | { |
535 | { |
530 | if (!perl || !term->perl.self) |
536 | if (!perl || !term->perl.self) |
531 | return false; |
537 | return false; |
532 | |
538 | |
533 | localise_env set_environ (perl_environ); |
539 | localise_env set_environ (perl_environ); |
… | |
… | |
815 | } *civ, const_iv[] = { |
821 | } *civ, const_iv[] = { |
816 | # define const_iv(name) { # name, (IV)name } |
822 | # define const_iv(name) { # name, (IV)name } |
817 | const_iv (HOOK_INIT), |
823 | const_iv (HOOK_INIT), |
818 | const_iv (HOOK_DESTROY), |
824 | const_iv (HOOK_DESTROY), |
819 | const_iv (HOOK_ACTION), |
825 | const_iv (HOOK_ACTION), |
|
|
826 | const_iv (HOOK_OSC_SEQ), |
|
|
827 | const_iv (HOOK_OSC_SEQ_PERL), |
820 | |
828 | |
821 | const_iv (NUM_RESOURCES), |
829 | const_iv (NUM_RESOURCES), |
822 | const_iv (DEFAULT_RSTYLE), |
830 | const_iv (DEFAULT_RSTYLE), |
823 | const_iv (OVERLAY_RSTYLE), |
831 | const_iv (OVERLAY_RSTYLE), |
824 | const_iv (Color_Bits), |
832 | const_iv (Color_Bits), |
… | |
… | |
1020 | const_iv (XIMLineEnd), |
1028 | const_iv (XIMLineEnd), |
1021 | const_iv (XIMAbsolutePosition), |
1029 | const_iv (XIMAbsolutePosition), |
1022 | const_iv (XIMDontChange), |
1030 | const_iv (XIMDontChange), |
1023 | # endif |
1031 | # endif |
1024 | # endif |
1032 | # endif |
|
|
1033 | |
|
|
1034 | /* DEC private modes */ |
|
|
1035 | const_iv (PrivMode_132), |
|
|
1036 | const_iv (PrivMode_132OK), |
|
|
1037 | const_iv (PrivMode_rVideo), |
|
|
1038 | const_iv (PrivMode_relOrigin), |
|
|
1039 | const_iv (PrivMode_Screen), |
|
|
1040 | const_iv (PrivMode_Autowrap), |
|
|
1041 | const_iv (PrivMode_aplCUR), |
|
|
1042 | const_iv (PrivMode_aplKP), |
|
|
1043 | const_iv (PrivMode_HaveBackSpace), |
|
|
1044 | const_iv (PrivMode_BackSpace), |
|
|
1045 | const_iv (PrivMode_ShiftKeys), |
|
|
1046 | const_iv (PrivMode_VisibleCursor), |
|
|
1047 | const_iv (PrivMode_MouseX10), |
|
|
1048 | const_iv (PrivMode_MouseX11), |
|
|
1049 | const_iv (PrivMode_scrollBar), |
|
|
1050 | const_iv (PrivMode_TtyOutputInh), |
|
|
1051 | const_iv (PrivMode_Keypress), |
|
|
1052 | const_iv (PrivMode_smoothScroll), |
|
|
1053 | const_iv (PrivMode_vt52), |
|
|
1054 | const_iv (PrivMode_LFNL), |
|
|
1055 | const_iv (PrivMode_MouseBtnEvent), |
|
|
1056 | const_iv (PrivMode_MouseAnyEvent), |
|
|
1057 | const_iv (PrivMode_BracketPaste), |
|
|
1058 | const_iv (PrivMode_ExtMouseUTF8), |
|
|
1059 | const_iv (PrivMode_ExtMouseUrxvt), |
|
|
1060 | const_iv (PrivMode_BlinkingCursor), |
|
|
1061 | const_iv (PrivMode_mouse_report), |
|
|
1062 | const_iv (PrivMode_Default), |
1025 | }; |
1063 | }; |
1026 | |
1064 | |
1027 | for (civ = const_iv + ecb_array_length (const_iv); civ > const_iv; civ--) |
1065 | for (civ = const_iv + ecb_array_length (const_iv); civ > const_iv; civ--) |
1028 | newCONSTSUB (stash, (char *)civ[-1].name, newSViv (civ[-1].iv)); |
1066 | newCONSTSUB (stash, (char *)civ[-1].name, newSViv (civ[-1].iv)); |
1029 | } |
1067 | } |
1030 | |
1068 | |
1031 | void |
1069 | void |
1032 | log (const char *msg) |
1070 | log (utf8_string msg) |
1033 | CODE: |
1071 | CODE: |
1034 | rxvt_log ("%s", msg); |
1072 | rxvt_log ("%s", msg); |
1035 | |
1073 | |
1036 | void |
1074 | void |
1037 | warn (const char *msg) |
1075 | warn (utf8_string msg) |
1038 | CODE: |
1076 | CODE: |
1039 | rxvt_warn ("%s", msg); |
1077 | rxvt_warn ("%s", msg); |
1040 | |
1078 | |
1041 | void |
1079 | void |
1042 | fatal (const char *msg) |
1080 | fatal (utf8_string msg) |
1043 | CODE: |
1081 | CODE: |
1044 | rxvt_fatal ("%s", msg); |
1082 | rxvt_fatal ("%s", msg); |
1045 | |
1083 | |
1046 | void |
1084 | void |
1047 | _exit (int status) |
1085 | _exit (int status) |
… | |
… | |
1287 | rxvt_term::ungrab () |
1325 | rxvt_term::ungrab () |
1288 | CODE: |
1326 | CODE: |
1289 | ungrab (THIS); |
1327 | ungrab (THIS); |
1290 | |
1328 | |
1291 | int |
1329 | int |
1292 | rxvt_term::XStringToKeysym (char *string) |
1330 | rxvt_term::XStringToKeysym (octet_string string) |
1293 | CODE: |
1331 | CODE: |
1294 | RETVAL = XStringToKeysym (string); |
1332 | RETVAL = XStringToKeysym (string); |
1295 | OUTPUT: RETVAL |
1333 | OUTPUT: RETVAL |
1296 | |
1334 | |
1297 | char * |
1335 | char * |
… | |
… | |
1336 | |
1374 | |
1337 | SV * |
1375 | SV * |
1338 | rxvt_term::locale_encode (SV *str) |
1376 | rxvt_term::locale_encode (SV *str) |
1339 | CODE: |
1377 | CODE: |
1340 | { |
1378 | { |
|
|
1379 | if (!SvOK (str)) |
|
|
1380 | XSRETURN_UNDEF; |
|
|
1381 | |
1341 | wchar_t *wstr = sv2wcs (str); |
1382 | wchar_t *wstr = sv2wcs (str); |
1342 | |
1383 | |
1343 | rxvt_push_locale (THIS->locale); |
1384 | rxvt_push_locale (THIS->locale); |
1344 | char *mbstr = rxvt_wcstombs (wstr); |
1385 | char *mbstr = rxvt_wcstombs (wstr); |
1345 | rxvt_pop_locale (); |
1386 | rxvt_pop_locale (); |
… | |
… | |
1354 | |
1395 | |
1355 | SV * |
1396 | SV * |
1356 | rxvt_term::locale_decode (SV *octets) |
1397 | rxvt_term::locale_decode (SV *octets) |
1357 | CODE: |
1398 | CODE: |
1358 | { |
1399 | { |
|
|
1400 | if (!SvOK (octets)) |
|
|
1401 | XSRETURN_UNDEF; |
|
|
1402 | |
1359 | STRLEN len; |
1403 | STRLEN len; |
1360 | char *data = SvPVbyte (octets, len); |
1404 | char *data = SvPVbyte (octets, len); |
1361 | |
1405 | |
1362 | rxvt_push_locale (THIS->locale); |
1406 | rxvt_push_locale (THIS->locale); |
1363 | wchar_t *wstr = rxvt_mbstowcs (data, len); |
1407 | wchar_t *wstr = rxvt_mbstowcs (data, len); |
… | |
… | |
1387 | #define TERM_OFFSET_saveLines TERM_OFFSET(saveLines) |
1431 | #define TERM_OFFSET_saveLines TERM_OFFSET(saveLines) |
1388 | #define TERM_OFFSET_total_rows TERM_OFFSET(total_rows) |
1432 | #define TERM_OFFSET_total_rows TERM_OFFSET(total_rows) |
1389 | #define TERM_OFFSET_top_row TERM_OFFSET(top_row) |
1433 | #define TERM_OFFSET_top_row TERM_OFFSET(top_row) |
1390 | |
1434 | |
1391 | int |
1435 | int |
1392 | rxvt_term::width () |
1436 | rxvt_term::width (int new_value = NO_INIT) |
1393 | ALIAS: |
1437 | ALIAS: |
1394 | width = TERM_OFFSET_width |
1438 | width = TERM_OFFSET_width |
1395 | height = TERM_OFFSET_height |
1439 | height = TERM_OFFSET_height |
1396 | fwidth = TERM_OFFSET_fwidth |
1440 | fwidth = TERM_OFFSET_fwidth |
1397 | fheight = TERM_OFFSET_fheight |
1441 | fheight = TERM_OFFSET_fheight |
… | |
… | |
1407 | saveLines = TERM_OFFSET_saveLines |
1451 | saveLines = TERM_OFFSET_saveLines |
1408 | total_rows = TERM_OFFSET_total_rows |
1452 | total_rows = TERM_OFFSET_total_rows |
1409 | top_row = TERM_OFFSET_top_row |
1453 | top_row = TERM_OFFSET_top_row |
1410 | CODE: |
1454 | CODE: |
1411 | RETVAL = *(int *)((char *)THIS + ix); |
1455 | RETVAL = *(int *)((char *)THIS + ix); |
|
|
1456 | if (items > 1) |
|
|
1457 | *(int *)((char *)THIS + ix) = new_value; |
1412 | OUTPUT: |
1458 | OUTPUT: |
1413 | RETVAL |
1459 | RETVAL |
1414 | |
1460 | |
1415 | unsigned int |
1461 | unsigned int |
1416 | rxvt_term::ModLevel3Mask () |
1462 | rxvt_term::ModLevel3Mask () |
… | |
… | |
1418 | ModLevel3Mask = 0 |
1464 | ModLevel3Mask = 0 |
1419 | ModMetaMask = 1 |
1465 | ModMetaMask = 1 |
1420 | ModNumLockMask = 2 |
1466 | ModNumLockMask = 2 |
1421 | current_screen = 3 |
1467 | current_screen = 3 |
1422 | hidden_cursor = 4 |
1468 | hidden_cursor = 4 |
|
|
1469 | priv_modes = 5 |
1423 | CODE: |
1470 | CODE: |
1424 | switch (ix) |
1471 | switch (ix) |
1425 | { |
1472 | { |
1426 | case 0: RETVAL = THIS->ModLevel3Mask; break; |
1473 | case 0: RETVAL = THIS->ModLevel3Mask; break; |
1427 | case 1: RETVAL = THIS->ModMetaMask; break; |
1474 | case 1: RETVAL = THIS->ModMetaMask; break; |
1428 | case 2: RETVAL = THIS->ModNumLockMask; break; |
1475 | case 2: RETVAL = THIS->ModNumLockMask; break; |
1429 | case 3: RETVAL = THIS->current_screen; break; |
1476 | case 3: RETVAL = THIS->current_screen; break; |
1430 | #ifdef CURSOR_BLINK |
1477 | #ifdef CURSOR_BLINK |
1431 | case 4: RETVAL = THIS->hidden_cursor; break; |
1478 | case 4: RETVAL = THIS->hidden_cursor; break; |
|
|
1479 | #else |
|
|
1480 | case 4: RETVAL = 0; break; |
1432 | #endif |
1481 | #endif |
|
|
1482 | case 5: RETVAL = THIS->priv_modes; break; |
1433 | } |
1483 | } |
1434 | OUTPUT: |
1484 | OUTPUT: |
1435 | RETVAL |
1485 | RETVAL |
1436 | |
1486 | |
1437 | char * |
1487 | char * |
… | |
… | |
1520 | THIS->rstyle = new_rstyle; |
1570 | THIS->rstyle = new_rstyle; |
1521 | OUTPUT: |
1571 | OUTPUT: |
1522 | RETVAL |
1572 | RETVAL |
1523 | |
1573 | |
1524 | int |
1574 | int |
1525 | rxvt_term::view_start (int newval = 1) |
1575 | rxvt_term::view_start (int newval = 0) |
1526 | PROTOTYPE: $;$ |
1576 | PROTOTYPE: $;$ |
1527 | CODE: |
1577 | CODE: |
1528 | { |
1578 | { |
1529 | RETVAL = THIS->view_start; |
1579 | RETVAL = THIS->view_start; |
1530 | |
1580 | if (items > 1) |
1531 | if (newval <= 0) |
|
|
1532 | THIS->scr_changeview (max (newval, THIS->top_row)); |
1581 | THIS->scr_changeview (newval); |
1533 | } |
1582 | } |
1534 | OUTPUT: |
1583 | OUTPUT: |
1535 | RETVAL |
1584 | RETVAL |
1536 | |
1585 | |
1537 | void |
1586 | void |
… | |
… | |
1572 | void |
1621 | void |
1573 | rxvt_term::want_refresh () |
1622 | rxvt_term::want_refresh () |
1574 | CODE: |
1623 | CODE: |
1575 | THIS->want_refresh = 1; |
1624 | THIS->want_refresh = 1; |
1576 | THIS->refresh_check (); |
1625 | THIS->refresh_check (); |
|
|
1626 | |
|
|
1627 | void |
|
|
1628 | rxvt_term::refresh_check () |
1577 | |
1629 | |
1578 | void |
1630 | void |
1579 | rxvt_term::ROW_t (int row_number, SV *new_text = 0, int start_col = 0, int start_ofs = 0, int max_len = MAX_COLS) |
1631 | rxvt_term::ROW_t (int row_number, SV *new_text = 0, int start_col = 0, int start_ofs = 0, int max_len = MAX_COLS) |
1580 | PPCODE: |
1632 | PPCODE: |
1581 | { |
1633 | { |
… | |
… | |
1744 | // find length |
1796 | // find length |
1745 | for (wchar_t *s = wstr; *s; s++) |
1797 | for (wchar_t *s = wstr; *s; s++) |
1746 | if (*s == NOCHAR) |
1798 | if (*s == NOCHAR) |
1747 | ; |
1799 | ; |
1748 | else if (IS_COMPOSE (*s)) |
1800 | else if (IS_COMPOSE (*s)) |
1749 | dlen += rxvt_composite.expand (*s, 0); |
1801 | dlen += rxvt_composite.expand (*s); |
1750 | else |
1802 | else |
1751 | dlen++; |
1803 | dlen++; |
1752 | |
1804 | |
1753 | wchar_t *rstr = rxvt_temp_buf<wchar_t> (dlen); |
1805 | wchar_t *rstr = rxvt_temp_buf<wchar_t> (dlen); |
1754 | |
1806 | |
… | |
… | |
1767 | } |
1819 | } |
1768 | OUTPUT: |
1820 | OUTPUT: |
1769 | RETVAL |
1821 | RETVAL |
1770 | |
1822 | |
1771 | void |
1823 | void |
1772 | rxvt_term::_resource (char *name, int index, SV *newval = 0) |
1824 | rxvt_term::_resource (octet_string name, int index, SV *newval = 0) |
1773 | PPCODE: |
1825 | PPCODE: |
1774 | { |
1826 | { |
1775 | static const struct resval { const char *name; int value; } *rs, rslist [] = { |
1827 | static const struct resval { const char *name; int value; } *rs, rslist [] = { |
1776 | # define def(name) { # name, Rs_ ## name }, |
1828 | # define def(name) { # name, Rs_ ## name }, |
1777 | # define reserve(name,count) |
1829 | # define reserve(name,count) |
… | |
… | |
1792 | index += rs->value; |
1844 | index += rs->value; |
1793 | } |
1845 | } |
1794 | else |
1846 | else |
1795 | { |
1847 | { |
1796 | --rs; |
1848 | --rs; |
1797 | name = ""; |
1849 | name = (octet_string)""; |
1798 | } |
1850 | } |
1799 | |
1851 | |
1800 | if (!IN_RANGE_EXC (index, 0, NUM_RESOURCES)) |
1852 | if (!IN_RANGE_EXC (index, 0, NUM_RESOURCES)) |
1801 | croak ("requested out-of-bound resource %s+%d,", name, index - rs->value); |
1853 | croak ("requested out-of-bound resource %s+%d,", name, index - rs->value); |
1802 | |
1854 | |
… | |
… | |
1815 | THIS->rs [index] = 0; |
1867 | THIS->rs [index] = 0; |
1816 | } |
1868 | } |
1817 | } |
1869 | } |
1818 | |
1870 | |
1819 | const char * |
1871 | const char * |
1820 | rxvt_term::x_resource (const char *name) |
1872 | rxvt_term::x_resource (octet_string name) |
1821 | |
1873 | |
1822 | bool |
1874 | bool |
1823 | rxvt_term::option (U8 optval, int set = -1) |
1875 | rxvt_term::option (U8 optval, int set = -1) |
1824 | CODE: |
1876 | CODE: |
1825 | { |
1877 | { |
… | |
… | |
1859 | } |
1911 | } |
1860 | } |
1912 | } |
1861 | OUTPUT: |
1913 | OUTPUT: |
1862 | RETVAL |
1914 | RETVAL |
1863 | |
1915 | |
|
|
1916 | SV * |
|
|
1917 | rxvt_term::lookup_keysym (int keysym, unsigned int state) |
|
|
1918 | CODE: |
|
|
1919 | { |
|
|
1920 | keysym_t *key = THIS->keyboard->lookup_keysym (THIS, keysym, state); |
|
|
1921 | RETVAL = key ? sv_2mortal (newSVpv (key->str, 0)) : &PL_sv_undef; |
|
|
1922 | } |
|
|
1923 | OUTPUT: |
|
|
1924 | RETVAL |
|
|
1925 | |
1864 | bool |
1926 | bool |
1865 | rxvt_term::bind_action (char *keysym, char *str) |
1927 | rxvt_term::bind_action (octet_string keysym, octet_string action) |
1866 | ALIAS: |
1928 | ALIAS: |
1867 | parse_keysym = 1 |
1929 | parse_keysym = 1 |
1868 | CODE: |
1930 | CODE: |
1869 | RETVAL = 0 < THIS->bind_action (keysym, str); |
1931 | RETVAL = 0 < THIS->bind_action (keysym, action); |
1870 | THIS->keyboard->register_done (); |
1932 | THIS->keyboard->register_done (); |
1871 | OUTPUT: |
1933 | OUTPUT: |
1872 | RETVAL |
1934 | RETVAL |
1873 | |
1935 | |
1874 | void |
1936 | void |
… | |
… | |
2262 | RETVAL |
2324 | RETVAL |
2263 | |
2325 | |
2264 | #endif |
2326 | #endif |
2265 | |
2327 | |
2266 | void |
2328 | void |
2267 | rxvt_term::set_background (rxvt_img *img, bool border = false) |
2329 | rxvt_term::clr_background () |
2268 | CODE: |
2330 | CODE: |
2269 | delete THIS->bg_img; |
2331 | delete THIS->bg_img; |
2270 | THIS->bg_img = 0; |
2332 | THIS->bg_img = 0; |
|
|
2333 | THIS->bg_flags = rxvt_term::BG_NEEDS_REFRESH; |
|
|
2334 | |
|
|
2335 | void |
|
|
2336 | rxvt_term::set_background (rxvt_img *img, bool border = false) |
|
|
2337 | CODE: |
|
|
2338 | delete THIS->bg_img; |
2271 | THIS->bg_flags = 0; |
2339 | THIS->bg_img = 0; |
|
|
2340 | THIS->bg_flags = rxvt_term::BG_NEEDS_REFRESH; |
2272 | |
2341 | |
2273 | if (img) // TODO: cannot be false |
2342 | //if (img) // TODO: cannot be false, maybe allow and get rid of clr_background? |
2274 | { |
2343 | { |
2275 | img = img->clone (); // own the img |
2344 | img = img->clone (); // own the img |
2276 | |
2345 | |
2277 | if (img->repeat != RepeatNormal) // X11 only supports RepeatNormal as bg pixmap |
2346 | if (img->repeat != RepeatNormal) // X11 only supports RepeatNormal as bg pixmap |
2278 | img->sub_rect (0, 0, |
2347 | img->sub_rect (0, 0, |
… | |
… | |
2286 | |
2355 | |
2287 | img->convert_format (XRenderFindVisualFormat (THIS->dpy, THIS->visual), THIS->pix_colors [Color_bg]) |
2356 | img->convert_format (XRenderFindVisualFormat (THIS->dpy, THIS->visual), THIS->pix_colors [Color_bg]) |
2288 | ->replace (img); |
2357 | ->replace (img); |
2289 | |
2358 | |
2290 | THIS->bg_img = img; |
2359 | THIS->bg_img = img; |
2291 | THIS->bg_flags |= rxvt_term::BG_NEEDS_REFRESH | rxvt_term::BG_INHIBIT_RENDER; |
|
|
2292 | |
2360 | |
2293 | if (!border) |
2361 | if (!border) |
2294 | THIS->bg_flags |= rxvt_term::BG_IS_TRANSPARENT; |
2362 | THIS->bg_flags |= rxvt_term::BG_IS_TRANSPARENT; |
2295 | } |
2363 | } |
2296 | |
2364 | |
… | |
… | |
2373 | |
2441 | |
2374 | void |
2442 | void |
2375 | rxvt_img::fill (SV *c, int x = 0, int y = 0, int w = THIS->w, int h = THIS->h) |
2443 | rxvt_img::fill (SV *c, int x = 0, int y = 0, int w = THIS->w, int h = THIS->h) |
2376 | PROTOTYPE: $;$$$$ |
2444 | PROTOTYPE: $;$$$$ |
2377 | INIT: |
2445 | INIT: |
2378 | rgba cc = parse_rgba (c, THIS->s); |
2446 | rxvt_screen screen; |
|
|
2447 | screen.set (THIS->d); |
|
|
2448 | rgba cc = parse_rgba (c, &screen); |
2379 | C_ARGS: cc, x, y, w, h |
2449 | C_ARGS: cc, x, y, w, h |
2380 | |
2450 | |
2381 | void |
2451 | void |
2382 | rxvt_img::DESTROY () |
2452 | rxvt_img::DESTROY () |
2383 | CODE: |
2453 | CODE: |
… | |
… | |
2441 | rxvt_img::rotate (int x, int y, rxvt_img::nv phi) |
2511 | rxvt_img::rotate (int x, int y, rxvt_img::nv phi) |
2442 | |
2512 | |
2443 | rxvt_img * |
2513 | rxvt_img * |
2444 | rxvt_img::tint (SV *c) |
2514 | rxvt_img::tint (SV *c) |
2445 | INIT: |
2515 | INIT: |
2446 | rgba cc = parse_rgba (c, THIS->s); |
2516 | rxvt_screen screen; |
|
|
2517 | screen.set (THIS->d); |
|
|
2518 | rgba cc = parse_rgba (c, &screen); |
2447 | C_ARGS: cc |
2519 | C_ARGS: cc |
2448 | |
2520 | |
2449 | rxvt_img * |
2521 | rxvt_img * |
2450 | rxvt_img::shade (rxvt_img::nv factor) |
2522 | rxvt_img::shade (rxvt_img::nv factor) |
2451 | |
2523 | |