… | |
… | |
106 | |
106 | |
107 | push urxvt::ext::selection_popup::hook, sub { |
107 | push urxvt::ext::selection_popup::hook, sub { |
108 | /a/ ? ("a to be" => sub { s/a/b/g } |
108 | /a/ ? ("a to be" => sub { s/a/b/g } |
109 | : () |
109 | : () |
110 | }; |
110 | }; |
|
|
111 | |
|
|
112 | Don't run it in a hook, otherwise the menu will grow and grow. Instead put |
|
|
113 | it at the toplevel of your extension. |
111 | |
114 | |
112 | =item searchable-scrollback<hotkey> (enabled by default) |
115 | =item searchable-scrollback<hotkey> (enabled by default) |
113 | |
116 | |
114 | Adds regex search functionality to the scrollback buffer, triggered |
117 | Adds regex search functionality to the scrollback buffer, triggered |
115 | by a hotkey (default: C<M-s>). While in search mode, normal terminal |
118 | by a hotkey (default: C<M-s>). While in search mode, normal terminal |
… | |
… | |
143 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+):(\\d+):?$/vi +$2 \\Q$1\\E\\x0d/ |
146 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+):(\\d+):?$/vi +$2 \\Q$1\\E\\x0d/ |
144 | |
147 | |
145 | And this example matches the same,but replaces it with vi-commands you can |
148 | And this example matches the same,but replaces it with vi-commands you can |
146 | paste directly into your (vi :) editor: |
149 | paste directly into your (vi :) editor: |
147 | |
150 | |
148 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+(\\d+):?$/\\x1b:e \\Q$1\\E\\x0d:$2\\x0d/ |
151 | URxvt.selection-autotransform.0: s/^([^:[:space:]]+(\\d+):?$/:e \\Q$1\\E\\x0d:$2\\x0d/ |
149 | |
152 | |
150 | Of course, this can be modified to suit your needs and your editor :) |
153 | Of course, this can be modified to suit your needs and your editor :) |
151 | |
154 | |
152 | To expand the example above to typical perl error messages ("XXX at |
155 | To expand the example above to typical perl error messages ("XXX at |
153 | FILENAME line YYY."), you need a slightly more elaborate solution: |
156 | FILENAME line YYY."), you need a slightly more elaborate solution: |
154 | |
157 | |
155 | URxvt.selection.pattern-0: ( at .*? line \\d+\\.) |
158 | URxvt.selection.pattern-0: ( at .*? line \\d+[,.]) |
156 | URxvt.selection-autotransform.0: s/^ at (.*?) line (\\d+)\\.$/\x1b:e \\Q$1\E\\x0d:$2\\x0d/ |
159 | URxvt.selection-autotransform.0: s/^ at (.*?) line (\\d+)[,.]$/:e \\Q$1\E\\x0d:$2\\x0d/ |
157 | |
160 | |
158 | The first line tells the selection code to treat the unchanging part of |
161 | 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 |
162 | every error message as a selection pattern, and the second line transforms |
160 | the message into vi commands to load the file. |
163 | the message into vi commands to load the file. |
161 | |
164 | |
… | |
… | |
324 | |
327 | |
325 | =item on_start $term |
328 | =item on_start $term |
326 | |
329 | |
327 | Called at the very end of initialisation of a new terminal, just before |
330 | Called at the very end of initialisation of a new terminal, just before |
328 | returning to the mainloop. |
331 | returning to the mainloop. |
|
|
332 | |
|
|
333 | =item on_child_start $term, $pid |
|
|
334 | |
|
|
335 | Called just after the child process has been C<fork>ed. |
|
|
336 | |
|
|
337 | =item on_child_exit $term, $status |
|
|
338 | |
|
|
339 | Called just after the child process has exited. C<$status> is the status |
|
|
340 | from C<waitpid>. |
329 | |
341 | |
330 | =item on_sel_make $term, $eventtime |
342 | =item on_sel_make $term, $eventtime |
331 | |
343 | |
332 | Called whenever a selection has been made by the user, but before the |
344 | Called whenever a selection has been made by the user, but before the |
333 | selection text is copied, so changes to the beginning, end or type of the |
345 | selection text is copied, so changes to the beginning, end or type of the |
… | |
… | |
744 | } |
756 | } |
745 | |
757 | |
746 | $retval |
758 | $retval |
747 | } |
759 | } |
748 | |
760 | |
749 | sub exec_async(@) { |
|
|
750 | my $pid = fork; |
|
|
751 | |
|
|
752 | return |
|
|
753 | if !defined $pid or $pid; |
|
|
754 | |
|
|
755 | %ENV = %{ $TERM->env }; |
|
|
756 | |
|
|
757 | exec @_; |
|
|
758 | _exit 255; |
|
|
759 | } |
|
|
760 | |
|
|
761 | # urxvt::term::extension |
761 | # urxvt::term::extension |
762 | |
762 | |
763 | package urxvt::term::extension; |
763 | package urxvt::term::extension; |
764 | |
764 | |
765 | sub enable { |
765 | sub enable { |
… | |
… | |
941 | =item $term->destroy |
941 | =item $term->destroy |
942 | |
942 | |
943 | Destroy the terminal object (close the window, free resources |
943 | Destroy the terminal object (close the window, free resources |
944 | etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event |
944 | etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event |
945 | watchers (timers, io watchers) are still active. |
945 | watchers (timers, io watchers) are still active. |
|
|
946 | |
|
|
947 | =item $term->exec_async ($cmd[, @args]) |
|
|
948 | |
|
|
949 | Works like the combination of the C<fork>/C<exec> builtins, which executes |
|
|
950 | ("starts") programs in the background. This function takes care of setting |
|
|
951 | the user environment before exec'ing the command (e.g. C<PATH>) and should |
|
|
952 | be preferred over explicit calls to C<exec> or C<system>. |
|
|
953 | |
|
|
954 | Returns the pid of the subprocess or C<undef> on error. |
|
|
955 | |
|
|
956 | =cut |
|
|
957 | |
|
|
958 | sub exec_async { |
|
|
959 | my $self = shift; |
|
|
960 | |
|
|
961 | my $pid = fork; |
|
|
962 | |
|
|
963 | return $pid |
|
|
964 | if !defined $pid or $pid; |
|
|
965 | |
|
|
966 | %ENV = %{ $self->env }; |
|
|
967 | |
|
|
968 | exec @_; |
|
|
969 | urxvt::_exit 255; |
|
|
970 | } |
946 | |
971 | |
947 | =item $isset = $term->option ($optval[, $set]) |
972 | =item $isset = $term->option ($optval[, $set]) |
948 | |
973 | |
949 | Returns true if the option specified by C<$optval> is enabled, and |
974 | Returns true if the option specified by C<$optval> is enabled, and |
950 | optionally change it. All option values are stored by name in the hash |
975 | optionally change it. All option values are stored by name in the hash |