ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/urxvt.pm
(Generate patch)

Comparing rxvt-unicode/src/urxvt.pm (file contents):
Revision 1.107 by root, Wed Jan 18 21:30:50 2006 UTC vs.
Revision 1.108 by root, Thu Jan 19 09:47:15 2006 UTC

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
145And this example matches the same,but replaces it with vi-commands you can 145And this example matches the same,but replaces it with vi-commands you can
146paste directly into your (vi :) editor: 146paste 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
150Of course, this can be modified to suit your needs and your editor :) 150Of course, this can be modified to suit your needs and your editor :)
151 151
152To expand the example above to typical perl error messages ("XXX at 152To expand the example above to typical perl error messages ("XXX at
153FILENAME line YYY."), you need a slightly more elaborate solution: 153FILENAME 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
158The first line tells the selection code to treat the unchanging part of 158The first line tells the selection code to treat the unchanging part of
159every error message as a selection pattern, and the second line transforms 159every error message as a selection pattern, and the second line transforms
160the message into vi commands to load the file. 160the message into vi commands to load the file.
161 161
324 324
325=item on_start $term 325=item on_start $term
326 326
327Called at the very end of initialisation of a new terminal, just before 327Called at the very end of initialisation of a new terminal, just before
328returning to the mainloop. 328returning to the mainloop.
329
330=item on_child_start $term, $pid
331
332Called just after the child process has been C<fork>ed.
333
334=item on_child_exit $term, $status
335
336Called just after the child process has exited. C<$status> is the status
337from C<waitpid>.
329 338
330=item on_sel_make $term, $eventtime 339=item on_sel_make $term, $eventtime
331 340
332Called whenever a selection has been made by the user, but before the 341Called whenever a selection has been made by the user, but before the
333selection text is copied, so changes to the beginning, end or type of the 342selection text is copied, so changes to the beginning, end or type of the
744 } 753 }
745 754
746 $retval 755 $retval
747} 756}
748 757
749sub 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 758# urxvt::term::extension
762 759
763package urxvt::term::extension; 760package urxvt::term::extension;
764 761
765sub enable { 762sub enable {
941=item $term->destroy 938=item $term->destroy
942 939
943Destroy the terminal object (close the window, free resources 940Destroy the terminal object (close the window, free resources
944etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event 941etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event
945watchers (timers, io watchers) are still active. 942watchers (timers, io watchers) are still active.
943
944=item $term->exec_async ($cmd[, @args])
945
946Works like the combination of the C<fork>/C<exec> builtins, which executes
947("starts") programs in the background. This function takes care of setting
948the user environment before exec'ing the command (e.g. C<PATH>) and should
949be preferred over explicit calls to C<exec> or C<system>.
950
951Returns the pid of the subprocess or C<undef> on error.
952
953=cut
954
955sub 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}
946 968
947=item $isset = $term->option ($optval[, $set]) 969=item $isset = $term->option ($optval[, $set])
948 970
949Returns true if the option specified by C<$optval> is enabled, and 971Returns true if the option specified by C<$optval> is enabled, and
950optionally change it. All option values are stored by name in the hash 972optionally change it. All option values are stored by name in the hash

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines