use warnings; use Devel::Peek; package Grief; use overload '++' => \&_inc, '=' => \&_copy, ; use Inline C => Config => BUILD_NOISY => 1; use Inline C => <<'EOC'; typedef struct { long num; } Number; SV * new(SV * x) { Number * num_obj; SV * obj_ref, * obj; New(1, num_obj, 1, Number); if(num_obj == NULL) croak("Failed to allocate memory in new() function"); obj_ref = newSViv(0); obj = newSVrv(obj_ref, "Grief"); num_obj->num = SvUV(x); sv_setiv(obj, (IV)num_obj); SvREADONLY_on(obj); return obj_ref; } SV * _get_val(SV * obj) { return newSVuv(((Number*)SvIV(SvRV(obj)))->num); } void _inc(SV * obj, SV * second, SV * third) { (((Number*)SvIV(SvRV(obj)))->num)++; } SV * _copy(SV * arg_obj, SV * second, SV * third) { Number * num_obj; SV * obj_ref, * obj; printf( "_copy:%p %p %p\n", arg_obj, second, third ); New(1, num_obj, 1, Number); if(num_obj == NULL) croak("Failed to allocate memory in _copy() function"); obj_ref = newSViv(0); obj = newSVrv(obj_ref, "Grief"); num_obj->num = ((Number*)SvIV(SvRV(arg_obj)))->num; sv_setiv(obj, (IV)num_obj); SvREADONLY_on(obj); return obj_ref; } void DESTROY(SV * obj) { printf("Destroying ..."); Number * number = (Number*)SvIV(SvRV(obj)); Safefree(number); printf("... destroyed\n"); } EOC $num1 = Grief::new(113); $num2 = $num1; $num3 = _copy($num1, '', ''); #Run any one of the following 4 lines $num1++; # _copy() gets called, 3 objects DESTROYed #$num2++; # _copy() gets called, 3 objects DESTROYed #_inc($num1, '', ''); # no _copy(), 2 objects DESTROYed #_inc($num2, '', ''); # no _copy(), 2 objects DESTROYed print _get_val($num2)," | ", _get_val($num3), "\n";
In reply to Re^4: Overloading '=' doesn't DWIM
by syphilis
in thread Overloading '=' doesn't DWIM
by syphilis
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |