… | |
… | |
143 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+):(\\d+):?$/vi +$2 \\Q$1\\E\\x0d/ |
143 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+):(\\d+):?$/vi +$2 \\Q$1\\E\\x0d/ |
144 | |
144 | |
145 | And this example matches the same,but replaces it with vi-commands you can |
145 | And this example matches the same,but replaces it with vi-commands you can |
146 | paste directly into your (vi :) editor: |
146 | paste directly into your (vi :) editor: |
147 | |
147 | |
148 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+(\\d+):?$/\\x1b:e \\Q$1\\E\\x0d:$2\\x0d/ |
148 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+(\\d+):?$/:e \\Q$1\\E\\x0d:$2\\x0d/ |
149 | |
149 | |
150 | Of course, this can be modified to suit your needs and your editor :) |
150 | Of course, this can be modified to suit your needs and your editor :) |
151 | |
151 | |
152 | To expand the example above to typical perl error messages ("XXX at |
152 | To expand the example above to typical perl error messages ("XXX at |
153 | FILENAME line YYY."), you need a slightly more elaborate solution: |
153 | FILENAME line YYY."), you need a slightly more elaborate solution: |
154 | |
154 | |
155 | URxvt.selection.pattern-0: ( at .*? line \\d+\\.) |
155 | URxvt.selection.pattern-0: ( at .*? line \\d+[,.]) |
156 | URxvt.selection-autotransform.0: s/^ at (.*?) line (\\d+)\\.$/\x1b:e \\Q$1\E\\x0d:$2\\x0d/ |
156 | URxvt.selection-autotransform.0: s/^ at (.*?) line (\\d+)[,.]$/:e \\Q$1\E\\x0d:$2\\x0d/ |
157 | |
157 | |
158 | The first line tells the selection code to treat the unchanging part of |
158 | The first line tells the selection code to treat the unchanging part of |
159 | every error message as a selection pattern, and the second line transforms |
159 | every error message as a selection pattern, and the second line transforms |
160 | the message into vi commands to load the file. |
160 | the message into vi commands to load the file. |
161 | |
161 | |
… | |
… | |
163 | |
163 | |
164 | Uses per-line display filtering (C<on_line_update>) to underline urls and |
164 | Uses per-line display filtering (C<on_line_update>) to underline urls and |
165 | make them clickable. When middle-clicked, the program specified in the |
165 | make them clickable. When middle-clicked, the program specified in the |
166 | resource C<urlLauncher> (default C<x-www-browser>) will be started with |
166 | resource C<urlLauncher> (default C<x-www-browser>) will be started with |
167 | the URL as first argument. |
167 | the URL as first argument. |
|
|
168 | |
|
|
169 | =item automove-background |
|
|
170 | |
|
|
171 | This is basically a one-line extension that dynamically changes the background pixmap offset |
|
|
172 | to the window position, in effect creating the same effect as pseudo transparency with |
|
|
173 | a custom pixmap. No scaling is supported in this mode. Exmaple: |
|
|
174 | |
|
|
175 | @@RXVT_NAME@@ -pixmap background.xpm -pe automove-background |
168 | |
176 | |
169 | =item block-graphics-to-ascii |
177 | =item block-graphics-to-ascii |
170 | |
178 | |
171 | A not very useful example of filtering all text output to the terminal, |
179 | A not very useful example of filtering all text output to the terminal, |
172 | by replacing all line-drawing characters (U+2500 .. U+259F) by a |
180 | by replacing all line-drawing characters (U+2500 .. U+259F) by a |
… | |
… | |
317 | =item on_start $term |
325 | =item on_start $term |
318 | |
326 | |
319 | Called at the very end of initialisation of a new terminal, just before |
327 | Called at the very end of initialisation of a new terminal, just before |
320 | returning to the mainloop. |
328 | returning to the mainloop. |
321 | |
329 | |
|
|
330 | =item on_child_start $term, $pid |
|
|
331 | |
|
|
332 | Called just after the child process has been C<fork>ed. |
|
|
333 | |
|
|
334 | =item on_child_exit $term, $status |
|
|
335 | |
|
|
336 | Called just after the child process has exited. C<$status> is the status |
|
|
337 | from C<waitpid>. |
|
|
338 | |
322 | =item on_sel_make $term, $eventtime |
339 | =item on_sel_make $term, $eventtime |
323 | |
340 | |
324 | Called whenever a selection has been made by the user, but before the |
341 | Called whenever a selection has been made by the user, but before the |
325 | selection text is copied, so changes to the beginning, end or type of the |
342 | selection text is copied, so changes to the beginning, end or type of the |
326 | selection will be honored. |
343 | selection will be honored. |
… | |
… | |
433 | |
450 | |
434 | =item on_focus_out $term |
451 | =item on_focus_out $term |
435 | |
452 | |
436 | Called wheneever the window loses keyboard focus, before rxvt-unicode does |
453 | Called wheneever the window loses keyboard focus, before rxvt-unicode does |
437 | focus out processing. |
454 | focus out processing. |
|
|
455 | |
|
|
456 | =item on_configure_notify $term, $event |
438 | |
457 | |
439 | =item on_key_press $term, $event, $keysym, $octets |
458 | =item on_key_press $term, $event, $keysym, $octets |
440 | |
459 | |
441 | =item on_key_release $term, $event, $keysym |
460 | =item on_key_release $term, $event, $keysym |
442 | |
461 | |
… | |
… | |
620 | my $msg = join "", @_; |
639 | my $msg = join "", @_; |
621 | $msg .= "\n" |
640 | $msg .= "\n" |
622 | unless $msg =~ /\n$/; |
641 | unless $msg =~ /\n$/; |
623 | urxvt::warn ($msg); |
642 | urxvt::warn ($msg); |
624 | }; |
643 | }; |
625 | |
|
|
626 | # %ENV is the original startup environment |
|
|
627 | delete $ENV{IFS}; |
|
|
628 | delete $ENV{CDPATH}; |
|
|
629 | delete $ENV{BASH_ENV}; |
|
|
630 | $ENV{PATH} = "/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/opt/bin:/opt/sbin"; |
|
|
631 | } |
644 | } |
632 | |
645 | |
633 | my $verbosity = $ENV{URXVT_PERL_VERBOSITY}; |
646 | my $verbosity = $ENV{URXVT_PERL_VERBOSITY}; |
634 | |
647 | |
635 | sub verbose { |
648 | sub verbose { |
… | |
… | |
740 | } |
753 | } |
741 | |
754 | |
742 | $retval |
755 | $retval |
743 | } |
756 | } |
744 | |
757 | |
745 | sub exec_async(@) { |
|
|
746 | my $pid = fork; |
|
|
747 | |
|
|
748 | return |
|
|
749 | if !defined $pid or $pid; |
|
|
750 | |
|
|
751 | %ENV = %{ $TERM->env }; |
|
|
752 | |
|
|
753 | exec @_; |
|
|
754 | _exit 255; |
|
|
755 | } |
|
|
756 | |
|
|
757 | # urxvt::term::extension |
758 | # urxvt::term::extension |
758 | |
759 | |
759 | package urxvt::term::extension; |
760 | package urxvt::term::extension; |
760 | |
761 | |
761 | sub enable { |
762 | sub enable { |
… | |
… | |
938 | |
939 | |
939 | Destroy the terminal object (close the window, free resources |
940 | Destroy the terminal object (close the window, free resources |
940 | etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event |
941 | etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event |
941 | watchers (timers, io watchers) are still active. |
942 | watchers (timers, io watchers) are still active. |
942 | |
943 | |
|
|
944 | =item $term->exec_async ($cmd[, @args]) |
|
|
945 | |
|
|
946 | Works like the combination of the C<fork>/C<exec> builtins, which executes |
|
|
947 | ("starts") programs in the background. This function takes care of setting |
|
|
948 | the user environment before exec'ing the command (e.g. C<PATH>) and should |
|
|
949 | be preferred over explicit calls to C<exec> or C<system>. |
|
|
950 | |
|
|
951 | Returns the pid of the subprocess or C<undef> on error. |
|
|
952 | |
|
|
953 | =cut |
|
|
954 | |
|
|
955 | sub exec_async { |
|
|
956 | my $self = shift; |
|
|
957 | |
|
|
958 | my $pid = fork; |
|
|
959 | |
|
|
960 | return $pid |
|
|
961 | if !defined $pid or $pid; |
|
|
962 | |
|
|
963 | %ENV = %{ $self->env }; |
|
|
964 | |
|
|
965 | exec @_; |
|
|
966 | urxvt::_exit 255; |
|
|
967 | } |
|
|
968 | |
943 | =item $isset = $term->option ($optval[, $set]) |
969 | =item $isset = $term->option ($optval[, $set]) |
944 | |
970 | |
945 | Returns true if the option specified by C<$optval> is enabled, and |
971 | Returns true if the option specified by C<$optval> is enabled, and |
946 | optionally change it. All option values are stored by name in the hash |
972 | optionally change it. All option values are stored by name in the hash |
947 | C<%urxvt::OPTION>. Options not enabled in this binary are not in the hash. |
973 | C<%urxvt::OPTION>. Options not enabled in this binary are not in the hash. |
… | |
… | |
949 | Here is a a likely non-exhaustive list of option names, please see the |
975 | Here is a a likely non-exhaustive list of option names, please see the |
950 | source file F</src/optinc.h> to see the actual list: |
976 | source file F</src/optinc.h> to see the actual list: |
951 | |
977 | |
952 | borderLess console cursorBlink cursorUnderline hold iconic insecure |
978 | borderLess console cursorBlink cursorUnderline hold iconic insecure |
953 | intensityStyles jumpScroll loginShell mapAlert meta8 mouseWheelScrollPage |
979 | intensityStyles jumpScroll loginShell mapAlert meta8 mouseWheelScrollPage |
954 | pastableTabs pointerBlank reverseVideo scrollBar scrollBar_floating |
980 | override-redirect pastableTabs pointerBlank reverseVideo scrollBar |
955 | scrollBar_right scrollTtyKeypress scrollTtyOutput scrollWithBuffer |
981 | scrollBar_floating scrollBar_right scrollTtyKeypress scrollTtyOutput |
956 | secondaryScreen secondaryScroll skipBuiltinGlyphs transparent |
982 | scrollWithBuffer secondaryScreen secondaryScroll skipBuiltinGlyphs |
957 | tripleclickwords utmpInhibit visualBell |
983 | transparent tripleclickwords utmpInhibit visualBell |
958 | |
984 | |
959 | =item $value = $term->resource ($name[, $newval]) |
985 | =item $value = $term->resource ($name[, $newval]) |
960 | |
986 | |
961 | Returns the current resource value associated with a given name and |
987 | Returns the current resource value associated with a given name and |
962 | optionally sets a new value. Setting values is most useful in the C<init> |
988 | optionally sets a new value. Setting values is most useful in the C<init> |
… | |
… | |
979 | |
1005 | |
980 | answerbackstring backgroundPixmap backspace_key boldFont boldItalicFont |
1006 | answerbackstring backgroundPixmap backspace_key boldFont boldItalicFont |
981 | borderLess color cursorBlink cursorUnderline cutchars delete_key |
1007 | borderLess color cursorBlink cursorUnderline cutchars delete_key |
982 | display_name embed ext_bwidth fade font geometry hold iconName |
1008 | display_name embed ext_bwidth fade font geometry hold iconName |
983 | imFont imLocale inputMethod insecure int_bwidth intensityStyles |
1009 | imFont imLocale inputMethod insecure int_bwidth intensityStyles |
984 | italicFont jumpScroll lineSpace loginShell mapAlert menu meta8 modifier |
1010 | italicFont jumpScroll lineSpace loginShell mapAlert meta8 modifier |
985 | mouseWheelScrollPage name pastableTabs path perl_eval perl_ext_1 perl_ext_2 |
1011 | mouseWheelScrollPage name override_redirect pastableTabs path perl_eval |
986 | perl_lib pointerBlank pointerBlankDelay preeditType print_pipe pty_fd |
1012 | perl_ext_1 perl_ext_2 perl_lib pointerBlank pointerBlankDelay |
987 | reverseVideo saveLines scrollBar scrollBar_align scrollBar_floating |
1013 | preeditType print_pipe pty_fd reverseVideo saveLines scrollBar |
988 | scrollBar_right scrollBar_thickness scrollTtyKeypress scrollTtyOutput |
1014 | scrollBar_align scrollBar_floating scrollBar_right scrollBar_thickness |
989 | scrollWithBuffer scrollstyle secondaryScreen secondaryScroll selectstyle |
1015 | scrollTtyKeypress scrollTtyOutput scrollWithBuffer scrollstyle |
990 | shade term_name title transparent transparent_all tripleclickwords |
1016 | secondaryScreen secondaryScroll selectstyle shade term_name title |
991 | utmpInhibit visualBell |
1017 | transient_for transparent transparent_all tripleclickwords utmpInhibit |
|
|
1018 | visualBell |
992 | |
1019 | |
993 | =cut |
1020 | =cut |
994 | |
1021 | |
995 | sub resource($$;$) { |
1022 | sub resource($$;$) { |
996 | my ($self, $name) = (shift, shift); |
1023 | my ($self, $name) = (shift, shift); |
… | |
… | |
1588 | my $env = $self->{term}->env; |
1615 | my $env = $self->{term}->env; |
1589 | # we can't hope to reproduce the locale algorithm, so nuke LC_ALL and set LC_CTYPE. |
1616 | # we can't hope to reproduce the locale algorithm, so nuke LC_ALL and set LC_CTYPE. |
1590 | delete $env->{LC_ALL}; |
1617 | delete $env->{LC_ALL}; |
1591 | $env->{LC_CTYPE} = $self->{term}->locale; |
1618 | $env->{LC_CTYPE} = $self->{term}->locale; |
1592 | |
1619 | |
1593 | urxvt::term->new ($env, $self->{term}->resource ("name"), |
1620 | urxvt::term->new ($env, "popup", |
1594 | "--perl-lib" => "", "--perl-ext-common" => "", "-pty-fd" => -1, "-sl" => 0, "-b" => 0, |
1621 | "--perl-lib" => "", "--perl-ext-common" => "", |
|
|
1622 | "-pty-fd" => -1, "-sl" => 0, |
|
|
1623 | "-b" => 1, "-bd" => "grey80", "-bl", "-override-redirect", |
1595 | "--transient-for" => $self->{term}->parent, |
1624 | "--transient-for" => $self->{term}->parent, |
1596 | "-display" => $self->{term}->display_id, |
1625 | "-display" => $self->{term}->display_id, |
1597 | "-pe" => "urxvt-popup") |
1626 | "-pe" => "urxvt-popup") |
1598 | or die "unable to create popup window\n"; |
1627 | or die "unable to create popup window\n"; |
1599 | } |
1628 | } |
… | |
… | |
1651 | Start the timer. |
1680 | Start the timer. |
1652 | |
1681 | |
1653 | =item $timer = $timer->start ($tstamp) |
1682 | =item $timer = $timer->start ($tstamp) |
1654 | |
1683 | |
1655 | Set the event trigger time to C<$tstamp> and start the timer. |
1684 | Set the event trigger time to C<$tstamp> and start the timer. |
|
|
1685 | |
|
|
1686 | =item $timer = $timer->after ($delay) |
|
|
1687 | |
|
|
1688 | Like C<start>, but sets the expiry timer to c<urxvt::NOW + $delay>. |
1656 | |
1689 | |
1657 | =item $timer = $timer->stop |
1690 | =item $timer = $timer->stop |
1658 | |
1691 | |
1659 | Stop the timer. |
1692 | Stop the timer. |
1660 | |
1693 | |