From: root Date: Tue, 3 Jan 2006 19:10:54 +0000 (+0000) Subject: *** empty log message *** X-Git-Url: http://git.openbox.org/?a=commitdiff_plain;h=12ebe447d089041f2bfc1208663297326275ccc4;p=dana%2Furxvt.git *** empty log message *** --- diff --git a/src/perl/selection b/src/perl/selection index e77a83af..dd146a4a 100644 --- a/src/perl/selection +++ b/src/perl/selection @@ -9,7 +9,7 @@ sub on_keyboard_command { () } -sub on_selection_event { +sub on_sel_extend { warn "hiya\n";#d# () } diff --git a/src/rxvtperl.xs b/src/rxvtperl.xs index 621c15b5..f621c665 100644 --- a/src/rxvtperl.xs +++ b/src/rxvtperl.xs @@ -63,22 +63,32 @@ static SV * newSVptr (void *ptr, const char *klass) { HV *hv = newHV (); - hv_store (hv, "_ptr", 4, newSViv ((long)ptr), 0); + sv_magic ((SV *)hv, 0, PERL_MAGIC_ext, (char *)ptr, 0); return sv_bless (newRV_noinc ((SV *)hv), gv_stashpv (klass, 1)); } +static void +clearSVptr (SV *sv) +{ + if (SvROK (sv)) + sv = SvRV (sv); + + hv_clear ((HV *)sv); + sv_unmagic (sv, PERL_MAGIC_ext); +} + static long SvPTR (SV *sv, const char *klass) { if (!sv_derived_from (sv, klass)) croak ("object of type %s expected", klass); - IV iv = SvIV (*hv_fetch ((HV *)SvRV (sv), "_ptr", 4, 1)); + MAGIC *mg = mg_find (SvRV (sv), PERL_MAGIC_ext); - if (!iv) + if (!mg) croak ("perl code used %s object, but C++ object is already destroyed, caught", klass); - return (long)iv; + return (long)mg->mg_ptr; } #define newSVterm(term) SvREFCNT_inc ((SV *)term->self) @@ -188,6 +198,9 @@ struct overlay { overlay (rxvt_term *THIS, int x_, int y_, int w_, int h_, rend_t rstyle, int border); ~overlay (); + void show (); + void hide (); + void swap (); void set (int x, int y, SV *str, SV *rend); @@ -242,11 +255,14 @@ overlay::overlay (rxvt_term *THIS, int x_, int y_, int w_, int h_, rend_t rstyle } } + show (); THIS->want_refresh = 1; } overlay::~overlay () { + hide (); + for (int y = h; y--; ) { delete [] text[y]; @@ -259,6 +275,29 @@ overlay::~overlay () THIS->want_refresh = 1; } +void +overlay::show () +{ + char key[33]; sprintf (key, "%32lx", (long)this); + + HV *hv = (HV *)SvRV (*hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0)); + hv_store (hv, key, 32, newSViv ((long)this), 0); +} + +void +overlay::hide () +{ + SV **ovs = hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0); + + if (ovs) + { + char key[33]; sprintf (key, "%32lx", (long)this); + + HV *hv = (HV *)SvRV (*ovs); + hv_delete (hv, key, 32, G_DISCARD); + } +} + void overlay::swap () { int ov_x = max (0, min (MOD (x, THIS->ncol), THIS->ncol - w)); @@ -443,8 +482,7 @@ rxvt_perl_interp::invoke (rxvt_term *term, hook_type htype, ...) if (htype == HOOK_DESTROY) { - // TODO: clear magic - hv_clear ((HV *)SvRV ((SV *)term->self)); + clearSVptr ((SV *)term->self); SvREFCNT_dec ((SV *)term->self); } @@ -885,10 +923,6 @@ rxvt_term::overlay (int x, int y, int w, int h, int rstyle = OVERLAY_RSTYLE, int overlay *o = new overlay (THIS, x, y, w, h, rstyle, border); RETVAL = newSVptr ((void *)o, "urxvt::overlay"); o->self = (HV *)SvRV (RETVAL); - - HV *hv = (HV *)SvRV (*hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0)); - char key[33]; sprintf (key, "%32lx", (long)o); - hv_store (hv, key, 32, newSViv ((long)o), 0); } OUTPUT: RETVAL @@ -899,19 +933,13 @@ void overlay::set (int x, int y, SV *text, SV *rend = 0) void -overlay::DESTROY () - CODE: -{ - SV **ovs = hv_fetch ((HV *)SvRV ((SV *)THIS->THIS->self), "_overlay", 8, 0); - if (ovs) - { - HV *hv = (HV *)SvRV (*ovs); - char key[33]; sprintf (key, "%32lx", (long)THIS); - hv_delete (hv, key, 32, G_DISCARD); - } +overlay::show () - delete THIS; -} +void +overlay::hide () + +void +overlay::DESTROY () MODULE = urxvt PACKAGE = urxvt::timer diff --git a/src/urxvt.pm b/src/urxvt.pm index b53af1f3..869d3c98 100644 --- a/src/urxvt.pm +++ b/src/urxvt.pm @@ -41,7 +41,10 @@ You can activate them like this: =item selection -Miscellaneous selection modifications. +Intelligent selection. This etxension tries to be more intelligent when the user +extends selections (double-click). + +It also offers the following bindable event: =over 4 @@ -124,6 +127,15 @@ by calling C<< $term->selection >>. Returning a true value aborts selection grabbing. It will still be hilighted. +=item on_sel_extend $term + +Called whenever the user tries to extend the selection (e.g. with a double +click) and is either supposed to return false (normal operation), or +should extend the selection itelf and return true to suppress the built-in +processing. + +See the F example extension. + =item on_focus_in $term Called whenever the window gets the keyboard focus, before urxvt does @@ -463,7 +475,9 @@ right/bottom side, respectively. This method returns an urxvt::overlay object. The overlay will be visible as long as the perl object is referenced. -Currently, the only method on the C object is C: +The methods currently supported on C objects are: + +=over 4 =item $overlay->set ($x, $y, $text, $rend) @@ -471,6 +485,16 @@ Similar to C<< $term->ROW_t >> and C<< $term->ROW_r >> in that it puts text in rxvt-unicode's special encoding and an array of rendition values at a specific position inside the overlay. +=item $overlay->hide + +If visible, hide the overlay, but do not destroy it. + +=item $overlay->show + +If hidden, display the overlay again. + +=back + =item $cellwidth = $term->strwidth $string Returns the number of screen-cells this string would need. Correctly