1 | #! perl |
1 | #! perl |
|
|
2 | |
|
|
3 | =head1 NAME |
|
|
4 | |
|
|
5 | option-popup - option menu (enabled by default) |
|
|
6 | |
|
|
7 | =head1 DESCRIPTION |
|
|
8 | |
|
|
9 | Binds a popup menu to Ctrl-Button2 that lets you toggle (some) options at |
|
|
10 | runtime. |
|
|
11 | |
|
|
12 | Other extensions can extend this popup menu by pushing a code reference |
|
|
13 | onto C<@{ $term->{option_popup_hook} }>, which gets called whenever the |
|
|
14 | popup is being displayed. |
|
|
15 | |
|
|
16 | Its sole argument is the popup menu, which can be modified. It should |
|
|
17 | either return nothing or a string, the initial boolean value and a code |
|
|
18 | reference. The string will be used as button text and the code reference |
|
|
19 | will be called when the toggle changes, with the new boolean value as |
|
|
20 | first argument. |
|
|
21 | |
|
|
22 | The following will add an entry C<myoption> that changes |
|
|
23 | C<< $self->{myoption} >>: |
|
|
24 | |
|
|
25 | push @{ $self->{term}{option_popup_hook} }, sub { |
|
|
26 | ("my option" => $myoption, sub { $self->{myoption} = $_[0] }) |
|
|
27 | }; |
|
|
28 | |
|
|
29 | =cut |
2 | |
30 | |
3 | sub on_start { |
31 | sub on_start { |
4 | my ($self) = @_; |
32 | my ($self) = @_; |
5 | |
33 | |
6 | $self->grab_button (2, urxvt::ControlMask); |
34 | $self->grab_button (2, urxvt::ControlMask); |