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

Comparing rxvt-unicode/src/rxvtperl.xs (file contents):
Revision 1.16 by root, Tue Jan 3 17:34:44 2006 UTC vs.
Revision 1.23 by root, Wed Jan 4 04:42:45 2006 UTC

61//TODO: use magic 61//TODO: use magic
62static SV * 62static SV *
63newSVptr (void *ptr, const char *klass) 63newSVptr (void *ptr, const char *klass)
64{ 64{
65 HV *hv = newHV (); 65 HV *hv = newHV ();
66 hv_store (hv, "_ptr", 4, newSViv ((long)ptr), 0); 66 sv_magic ((SV *)hv, 0, PERL_MAGIC_ext, (char *)ptr, 0);
67 return sv_bless (newRV_noinc ((SV *)hv), gv_stashpv (klass, 1)); 67 return sv_bless (newRV_noinc ((SV *)hv), gv_stashpv (klass, 1));
68}
69
70static void
71clearSVptr (SV *sv)
72{
73 if (SvROK (sv))
74 sv = SvRV (sv);
75
76 hv_clear ((HV *)sv);
77 sv_unmagic (sv, PERL_MAGIC_ext);
68} 78}
69 79
70static long 80static long
71SvPTR (SV *sv, const char *klass) 81SvPTR (SV *sv, const char *klass)
72{ 82{
73 if (!sv_derived_from (sv, klass)) 83 if (!sv_derived_from (sv, klass))
74 croak ("object of type %s expected", klass); 84 croak ("object of type %s expected", klass);
75 85
76 IV iv = SvIV (*hv_fetch ((HV *)SvRV (sv), "_ptr", 4, 1)); 86 MAGIC *mg = mg_find (SvRV (sv), PERL_MAGIC_ext);
77 87
78 if (!iv) 88 if (!mg)
79 croak ("perl code used %s object, but C++ object is already destroyed, caught", klass); 89 croak ("perl code used %s object, but C++ object is already destroyed, caught", klass);
80 90
81 return (long)iv; 91 return (long)mg->mg_ptr;
82} 92}
83 93
84#define newSVterm(term) SvREFCNT_inc ((SV *)term->self) 94#define newSVterm(term) SvREFCNT_inc ((SV *)term->self)
85#define SvTERM(sv) (rxvt_term *)SvPTR (sv, "urxvt::term") 95#define SvTERM(sv) (rxvt_term *)SvPTR (sv, "urxvt::term")
86 96
185 text_t **text; 195 text_t **text;
186 rend_t **rend; 196 rend_t **rend;
187 197
188 overlay (rxvt_term *THIS, int x_, int y_, int w_, int h_, rend_t rstyle, int border); 198 overlay (rxvt_term *THIS, int x_, int y_, int w_, int h_, rend_t rstyle, int border);
189 ~overlay (); 199 ~overlay ();
200
201 void show ();
202 void hide ();
190 203
191 void swap (); 204 void swap ();
192 205
193 void set (int x, int y, SV *str, SV *rend); 206 void set (int x, int y, SV *str, SV *rend);
194}; 207};
240 *tp++ = 0x0020; 253 *tp++ = 0x0020;
241 *rp++ = r; 254 *rp++ = r;
242 } 255 }
243 } 256 }
244 257
258 show ();
245 THIS->want_refresh = 1; 259 THIS->want_refresh = 1;
246} 260}
247 261
248overlay::~overlay () 262overlay::~overlay ()
249{ 263{
264 hide ();
265
250 for (int y = h; y--; ) 266 for (int y = h; y--; )
251 { 267 {
252 delete [] text[y]; 268 delete [] text[y];
253 delete [] rend[y]; 269 delete [] rend[y];
254 } 270 }
255 271
256 delete [] text; 272 delete [] text;
257 delete [] rend; 273 delete [] rend;
258 274
259 THIS->want_refresh = 1; 275 THIS->want_refresh = 1;
276}
277
278void
279overlay::show ()
280{
281 char key[33]; sprintf (key, "%32lx", (long)this);
282
283 HV *hv = (HV *)SvRV (*hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0));
284 hv_store (hv, key, 32, newSViv ((long)this), 0);
285}
286
287void
288overlay::hide ()
289{
290 SV **ovs = hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0);
291
292 if (ovs)
293 {
294 char key[33]; sprintf (key, "%32lx", (long)this);
295
296 HV *hv = (HV *)SvRV (*ovs);
297 hv_delete (hv, key, 32, G_DISCARD);
298 }
260} 299}
261 300
262void overlay::swap () 301void overlay::swap ()
263{ 302{
264 int ov_x = max (0, min (MOD (x, THIS->ncol), THIS->ncol - w)); 303 int ov_x = max (0, min (MOD (x, THIS->ncol), THIS->ncol - w));
367 if (htype == HOOK_INIT) // first hook ever called 406 if (htype == HOOK_INIT) // first hook ever called
368 { 407 {
369 term->self = (void *)newSVptr ((void *)term, "urxvt::term"); 408 term->self = (void *)newSVptr ((void *)term, "urxvt::term");
370 hv_store ((HV *)SvRV ((SV *)term->self), "_overlay", 8, newRV_noinc ((SV *)newHV ()), 0); 409 hv_store ((HV *)SvRV ((SV *)term->self), "_overlay", 8, newRV_noinc ((SV *)newHV ()), 0);
371 } 410 }
411 else if (!term->self)
412 return false; // perl not initialized for this instance
372 else if (htype == HOOK_DESTROY) 413 else if (htype == HOOK_DESTROY)
373 { 414 {
374 // handled later 415 // handled later
375 } 416 }
376 else if (htype == HOOK_REFRESH_BEGIN || htype == HOOK_REFRESH_END) 417 else if (htype == HOOK_REFRESH_BEGIN || htype == HOOK_REFRESH_END)
439 if (SvTRUE (ERRSV)) 480 if (SvTRUE (ERRSV))
440 rxvt_warn ("perl hook %d evaluation error: %s", htype, SvPV_nolen (ERRSV)); 481 rxvt_warn ("perl hook %d evaluation error: %s", htype, SvPV_nolen (ERRSV));
441 482
442 if (htype == HOOK_DESTROY) 483 if (htype == HOOK_DESTROY)
443 { 484 {
444 // TODO: clear magic
445 hv_clear ((HV *)SvRV ((SV *)term->self)); 485 clearSVptr ((SV *)term->self);
446 SvREFCNT_dec ((SV *)term->self); 486 SvREFCNT_dec ((SV *)term->self);
447 } 487 }
448 488
449 return count; 489 return count;
450 } 490 }
461 501
462PROTOTYPES: ENABLE 502PROTOTYPES: ENABLE
463 503
464BOOT: 504BOOT:
465{ 505{
466# define set_hookname(sym) av_store (hookname, PP_CONCAT(HOOK_, sym), newSVpv (PP_STRINGIFY(sym), 0))
467# define export_const(name) newCONSTSUB (gv_stashpv ("urxvt", 1), #name, newSViv (name)); 506# define export_const(name) newCONSTSUB (gv_stashpv ("urxvt", 1), # name, newSViv (name));
468 AV *hookname = get_av ("urxvt::HOOKNAME", 1); 507 AV *hookname = get_av ("urxvt::HOOKNAME", 1);
469 set_hookname (INIT); 508# define def(sym) av_store (hookname, HOOK_ ## sym, newSVpv (# sym, 0));
470 set_hookname (RESET); 509# include "hookinc.h"
471 set_hookname (START); 510# undef def
472 set_hookname (DESTROY);
473 set_hookname (SEL_BEGIN);
474 set_hookname (SEL_EXTEND);
475 set_hookname (SEL_MAKE);
476 set_hookname (SEL_GRAB);
477 set_hookname (SEL_CLICK);
478 set_hookname (FOCUS_IN);
479 set_hookname (FOCUS_OUT);
480 set_hookname (VIEW_CHANGE);
481 set_hookname (SCROLL_BACK);
482 set_hookname (TTY_ACTIVITY);
483 set_hookname (REFRESH_BEGIN);
484 set_hookname (REFRESH_END);
485 set_hookname (KEYBOARD_COMMAND);
486 set_hookname (MOUSE_CLICK);
487 set_hookname (MOUSE_MOVE);
488 511
489 export_const (DEFAULT_RSTYLE); 512 export_const (DEFAULT_RSTYLE);
490 export_const (OVERLAY_RSTYLE); 513 export_const (OVERLAY_RSTYLE);
491 export_const (RS_Bold); 514 export_const (RS_Bold);
492 export_const (RS_Italic); 515 export_const (RS_Italic);
667void 690void
668rxvt_term::ROW_t (int row_number, SV *new_text = 0, int start_col = 0) 691rxvt_term::ROW_t (int row_number, SV *new_text = 0, int start_col = 0)
669 PPCODE: 692 PPCODE:
670{ 693{
671 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) 694 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow))
672 croak ("row_number number of out range"); 695 XSRETURN_EMPTY;
673 696
674 line_t &l = ROW(row_number); 697 line_t &l = ROW(row_number);
675 698
676 if (GIMME_V != G_VOID) 699 if (GIMME_V != G_VOID)
677 { 700 {
714void 737void
715rxvt_term::ROW_r (int row_number, SV *new_rend = 0, int start_col = 0) 738rxvt_term::ROW_r (int row_number, SV *new_rend = 0, int start_col = 0)
716 PPCODE: 739 PPCODE:
717{ 740{
718 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) 741 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow))
719 croak ("row_number number of out range"); 742 XSRETURN_EMPTY;
720 743
721 line_t &l = ROW(row_number); 744 line_t &l = ROW(row_number);
722 745
723 if (GIMME_V != G_VOID) 746 if (GIMME_V != G_VOID)
724 { 747 {
754int 777int
755rxvt_term::ROW_l (int row_number, int new_length = -2) 778rxvt_term::ROW_l (int row_number, int new_length = -2)
756 CODE: 779 CODE:
757{ 780{
758 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow)) 781 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow))
759 croak ("row_number number of out range"); 782 XSRETURN_EMPTY;
760 783
761 line_t &l = ROW(row_number); 784 line_t &l = ROW(row_number);
762 RETVAL = l.l; 785 RETVAL = l.l < 0 ? THIS->ncol : l.l;
763 786
764 if (new_length >= -1) 787 if (new_length >= -1)
765 l.l = new_length; 788 l.l = new_length;
766} 789}
767 OUTPUT: 790 OUTPUT:
768 RETVAL 791 RETVAL
769 792
793bool
794rxvt_term::ROW_is_longer (int row_number)
795 CODE:
796{
797 if (!IN_RANGE_EXC (row_number, -THIS->nsaved, THIS->nrow))
798 XSRETURN_EMPTY;
799
800 line_t &l = ROW(row_number);
801 RETVAL = l.l < 0;
802}
803 OUTPUT:
804 RETVAL
805
770SV * 806SV *
771rxvt_term::special_encode (SV *str) 807rxvt_term::special_encode (SV *str)
772 CODE: 808 CODE:
773 abort ();//TODO 809 abort ();//TODO
774 810
780void 816void
781rxvt_term::_resource (char *name, int index, SV *newval = 0) 817rxvt_term::_resource (char *name, int index, SV *newval = 0)
782 PPCODE: 818 PPCODE:
783{ 819{
784 struct resval { const char *name; int value; } rslist [] = { 820 struct resval { const char *name; int value; } rslist [] = {
785# define Rs_def(name) { # name, Rs_ ## name }, 821# define def(name) { # name, Rs_ ## name },
786# define Rs_reserve(name,count) 822# define reserve(name,count)
787# include "rsinc.h" 823# include "rsinc.h"
788# undef Rs_def 824# undef def
789# undef Rs_reserve 825# undef reserve
790 }; 826 };
791 827
792 struct resval *rs = rslist + sizeof (rslist) / sizeof (rslist [0]); 828 struct resval *rs = rslist + sizeof (rslist) / sizeof (rslist [0]);
793 829
794 do { 830 do {
875rxvt_term::tt_write (SV *octets) 911rxvt_term::tt_write (SV *octets)
876 INIT: 912 INIT:
877 STRLEN len; 913 STRLEN len;
878 char *str = SvPVbyte (octets, len); 914 char *str = SvPVbyte (octets, len);
879 C_ARGS: 915 C_ARGS:
880 (unsigned char *)str, len 916 str, len
881 917
882SV * 918SV *
883rxvt_term::overlay (int x, int y, int w, int h, int rstyle = OVERLAY_RSTYLE, int border = 2) 919rxvt_term::overlay (int x, int y, int w, int h, int rstyle = OVERLAY_RSTYLE, int border = 2)
884 CODE: 920 CODE:
885{ 921{
886 overlay *o = new overlay (THIS, x, y, w, h, rstyle, border); 922 overlay *o = new overlay (THIS, x, y, w, h, rstyle, border);
887 RETVAL = newSVptr ((void *)o, "urxvt::overlay"); 923 RETVAL = newSVptr ((void *)o, "urxvt::overlay");
888 o->self = (HV *)SvRV (RETVAL); 924 o->self = (HV *)SvRV (RETVAL);
889
890 HV *hv = (HV *)SvRV (*hv_fetch ((HV *)SvRV ((SV *)THIS->self), "_overlay", 8, 0));
891 char key[33]; sprintf (key, "%32lx", (long)o);
892 hv_store (hv, key, 32, newSViv ((long)o), 0);
893} 925}
894 OUTPUT: 926 OUTPUT:
895 RETVAL 927 RETVAL
896 928
897MODULE = urxvt PACKAGE = urxvt::overlay 929MODULE = urxvt PACKAGE = urxvt::overlay
898 930
899void 931void
900overlay::set (int x, int y, SV *text, SV *rend = 0) 932overlay::set (int x, int y, SV *text, SV *rend = 0)
901 933
902void 934void
935overlay::show ()
936
937void
938overlay::hide ()
939
940void
903overlay::DESTROY () 941overlay::DESTROY ()
904 CODE:
905{
906 SV **ovs = hv_fetch ((HV *)SvRV ((SV *)THIS->THIS->self), "_overlay", 8, 0);
907 if (ovs)
908 {
909 HV *hv = (HV *)SvRV (*ovs);
910 char key[33]; sprintf (key, "%32lx", (long)THIS);
911 hv_delete (hv, key, 32, G_DISCARD);
912 }
913
914 delete THIS;
915}
916 942
917MODULE = urxvt PACKAGE = urxvt::timer 943MODULE = urxvt PACKAGE = urxvt::timer
918 944
919SV * 945SV *
920timer::new () 946timer::new ()

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines