Imager::ImgRaw T_IMAGER_IMAGE
Imager::Font::TT T_PTROBJ
Imager::IO T_PTROBJ
-Imager::Font::FT2 T_PTROBJ
Imager::FillHandle T_PTROBJ
-Imager::Internal::Hlines T_PTROBJ
const char * T_PV
-float T_FLOAT
+im_float T_FLOAT
float* T_ARRAY
undef_int T_IV_U
undef_neg_int T_IV_NEGU
HASH T_HVREF
utf8_str T_UTF8_STR
+i_img_dim T_IV_checked
+im_double T_NV_checked
+
# these types are for use by Inline, which can't handle types containing ::
Imager__Color T_PTROBJ_INV
if (SvOK($arg)) $var = INT2PTR($type,SvIV($arg));
else $var = NULL
-# the pre-5.8.0 T_AVREF input map was fixed in 5.8.0
-T_AVREF
- if (SvROK($arg) && SvTYPE(SvRV($arg))==SVt_PVAV)
- $var = (AV*)SvRV($arg);
- else
- Perl_croak(aTHX_ \"$var is not an array reference\")
-
# handles Imager objects rather than just raw objects
T_IMAGER_IMAGE
if (sv_derived_from($arg, \"Imager::ImgRaw\")) {
else
croak(\"$var is not of type ${(my $ntt=$ntype)=~s/__/::/g;\$ntt}\");
+T_NV_checked
+ {
+ SvGETMAGIC($arg);
+ if (SvROK($arg) && !SvAMAGIC($arg)) {
+ croak(\"Numeric argument '$var' shouldn't be a reference\");
+ }
+ else {
+ $var = ($type)SvNV($arg);
+ }
+ }
+
+T_IV_checked
+ {
+ SvGETMAGIC($arg);
+ if (SvROK($arg) && !SvAMAGIC($arg)) {
+ croak(\"Numeric argument '$var' shouldn't be a reference\");
+ }
+ else {
+ $var = ($type)SvIV($arg);
+ }
+ }
#############################################################################
OUTPUT
if ($var) {
SV *imobj = NEWSV(0, 0);
HV *hv = newHV();
- SV *hvref;
- SV *imgref;
sv_setref_pv(imobj, \"Imager::ImgRaw\", $var);
hv_store(hv, "IMG", 3, imobj, 0);
- $arg = sv_2mortal(sv_bless(newRV((SV*)hv), gv_stashpv("Imager", 1)));
+ $arg = sv_2mortal(sv_bless(newRV_noinc((SV*)hv), gv_stashpv("Imager", 1)));
}
else {
$arg = &PL_sv_undef;
}
+
+T_IV_checked
+ sv_setiv($arg, (IV)$var);
+
+T_NV_checked
+ sv_setnv($arg, (NV)$var);