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.106 by root, Wed Jan 18 19:44:22 2006 UTC vs.
Revision 1.109 by root, Thu Jan 19 16:07:09 2006 UTC

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
112Don't run it in a hook, otherwise the menu will grow and grow. Instead put
113it 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
114Adds regex search functionality to the scrollback buffer, triggered 117Adds regex search functionality to the scrollback buffer, triggered
115by a hotkey (default: C<M-s>). While in search mode, normal terminal 118by 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
145And this example matches the same,but replaces it with vi-commands you can 148And this example matches the same,but replaces it with vi-commands you can
146paste directly into your (vi :) editor: 149paste 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
150Of course, this can be modified to suit your needs and your editor :) 153Of course, this can be modified to suit your needs and your editor :)
151 154
152To expand the example above to typical perl error messages ("XXX at 155To expand the example above to typical perl error messages ("XXX at
153FILENAME line YYY."), you need a slightly more elaborate solution: 156FILENAME 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
158The first line tells the selection code to treat the unchanging part of 161The first line tells the selection code to treat the unchanging part of
159every error message as a selection pattern, and the second line transforms 162every error message as a selection pattern, and the second line transforms
160the message into vi commands to load the file. 163the message into vi commands to load the file.
161 164
324 327
325=item on_start $term 328=item on_start $term
326 329
327Called at the very end of initialisation of a new terminal, just before 330Called at the very end of initialisation of a new terminal, just before
328returning to the mainloop. 331returning to the mainloop.
332
333=item on_child_start $term, $pid
334
335Called just after the child process has been C<fork>ed.
336
337=item on_child_exit $term, $status
338
339Called just after the child process has exited. C<$status> is the status
340from C<waitpid>.
329 341
330=item on_sel_make $term, $eventtime 342=item on_sel_make $term, $eventtime
331 343
332Called whenever a selection has been made by the user, but before the 344Called 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 345selection text is copied, so changes to the beginning, end or type of the
630 my $msg = join "", @_; 642 my $msg = join "", @_;
631 $msg .= "\n" 643 $msg .= "\n"
632 unless $msg =~ /\n$/; 644 unless $msg =~ /\n$/;
633 urxvt::warn ($msg); 645 urxvt::warn ($msg);
634 }; 646 };
635
636 # %ENV is the original startup environment
637 delete $ENV{IFS};
638 delete $ENV{CDPATH};
639 delete $ENV{BASH_ENV};
640 $ENV{PATH} = "/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/opt/bin:/opt/sbin";
641} 647}
642 648
643my $verbosity = $ENV{URXVT_PERL_VERBOSITY}; 649my $verbosity = $ENV{URXVT_PERL_VERBOSITY};
644 650
645sub verbose { 651sub verbose {
750 } 756 }
751 757
752 $retval 758 $retval
753} 759}
754 760
755sub exec_async(@) {
756 my $pid = fork;
757
758 return
759 if !defined $pid or $pid;
760
761 %ENV = %{ $TERM->env };
762
763 exec @_;
764 _exit 255;
765}
766
767# urxvt::term::extension 761# urxvt::term::extension
768 762
769package urxvt::term::extension; 763package urxvt::term::extension;
770 764
771sub enable { 765sub enable {
947=item $term->destroy 941=item $term->destroy
948 942
949Destroy the terminal object (close the window, free resources 943Destroy the terminal object (close the window, free resources
950etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event 944etc.). Please note that @@RXVT_NAME@@ will not exit as long as any event
951watchers (timers, io watchers) are still active. 945watchers (timers, io watchers) are still active.
946
947=item $term->exec_async ($cmd[, @args])
948
949Works like the combination of the C<fork>/C<exec> builtins, which executes
950("starts") programs in the background. This function takes care of setting
951the user environment before exec'ing the command (e.g. C<PATH>) and should
952be preferred over explicit calls to C<exec> or C<system>.
953
954Returns the pid of the subprocess or C<undef> on error.
955
956=cut
957
958sub 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}
952 971
953=item $isset = $term->option ($optval[, $set]) 972=item $isset = $term->option ($optval[, $set])
954 973
955Returns true if the option specified by C<$optval> is enabled, and 974Returns true if the option specified by C<$optval> is enabled, and
956optionally change it. All option values are stored by name in the hash 975optionally change it. All option values are stored by name in the hash

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines