3 Imager::Color::Float T_PTROBJ
4 Imager::ImgRaw T_IMAGER_IMAGE
5 Imager::Font::TT T_PTROBJ
7 Imager::FillHandle T_PTROBJ
8 Imager::Internal::Hlines T_PTROBJ
13 undef_neg_int T_IV_NEGU
18 # these types are for use by Inline, which can't handle types containing ::
19 Imager__Color T_PTROBJ_INV
20 Imager__Color__Float T_PTROBJ_INV
21 Imager__ImgRaw T_IMAGER_IMAGE
22 Imager__FillHandle T_PTROBJ_INV
23 Imager__IO T_PTROBJ_INV
25 # mostly intended for non-Imager-core use
26 Imager T_IMAGER_FULL_IMAGE
30 # STRLEN isn't in the default typemap in older perls
33 #############################################################################
36 if (SvOK($arg)) $var = INT2PTR($type,SvIV($arg));
39 # the pre-5.8.0 T_AVREF input map was fixed in 5.8.0
41 if (SvROK($arg) && SvTYPE(SvRV($arg))==SVt_PVAV)
42 $var = (AV*)SvRV($arg);
44 Perl_croak(aTHX_ \"$var is not an array reference\")
46 # handles Imager objects rather than just raw objects
48 if (sv_derived_from($arg, \"Imager::ImgRaw\")) {
49 IV tmp = SvIV((SV*)SvRV($arg));
50 $var = INT2PTR($type,tmp);
52 else if (sv_derived_from($arg, \"Imager\") &&
53 SvTYPE(SvRV($arg)) == SVt_PVHV) {
54 HV *hv = (HV *)SvRV($arg);
55 SV **sv = hv_fetch(hv, \"IMG\", 3, 0);
56 if (sv && *sv && sv_derived_from(*sv, \"Imager::ImgRaw\")) {
57 IV tmp = SvIV((SV*)SvRV(*sv));
58 $var = INT2PTR($type,tmp);
61 Perl_croak(aTHX_ \"$var is not of type Imager::ImgRaw\");
64 Perl_croak(aTHX_ \"$var is not of type Imager::ImgRaw\");
67 if (sv_derived_from($arg, \"Imager\") &&
68 SvTYPE(SvRV($arg)) == SVt_PVHV) {
69 HV *hv = (HV *)SvRV($arg);
70 SV **sv = hv_fetch(hv, \"IMG\", 3, 0);
71 if (sv && *sv && sv_derived_from(*sv, \"Imager::ImgRaw\")) {
72 IV tmp = SvIV((SV*)SvRV(*sv));
73 $var = INT2PTR($type,tmp);
76 Perl_croak(aTHX_ \"$var is not of type Imager::ImgRaw\");
79 Perl_croak(aTHX_ \"$var is not of type Imager\");
81 # same as T_PTROBJ, but replace __ with ::, the opposite of the way
82 # xsubpp's processing works
83 # this is to compensate for Inline's problem with type names containing ::
85 if (sv_derived_from($arg, \"${(my $ntt=$ntype)=~s/__/::/g;\$ntt}\")) {
86 IV tmp = SvIV((SV*)SvRV($arg));
87 $var = INT2PTR($type,tmp);
90 croak(\"$var is not of type ${(my $ntt=$ntype)=~s/__/::/g;\$ntt}\");
93 $var = i_sv_off_t(aTHX_ $arg);
95 #############################################################################
98 if ($var == 0) $arg=&PL_sv_undef;
99 else sv_setiv($arg, (IV)$var);
101 if ($var < 0) $arg=&PL_sv_undef;
102 else sv_setiv($arg, (IV)$var);
104 sv_setiv($arg, (IV)$var);
108 sv_setref_pv($arg, \"Imager::ImgRaw\", (void*)$var);
111 sv_setref_pv($arg, \"${(my $ntt=$ntype)=~s/__/::/g;\$ntt}\", (void*)$var);
113 # ugh, the things we do for ease of use
114 # this isn't suitable in some cases
117 SV *imobj = NEWSV(0, 0);
119 sv_setref_pv(imobj, \"Imager::ImgRaw\", $var);
120 hv_store(hv, "IMG", 3, imobj, 0);
121 $arg = sv_2mortal(sv_bless(newRV_noinc((SV*)hv), gv_stashpv("Imager", 1)));
127 $arg = i_new_sv_off_t(aTHX_ $var);