X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=Nary.xs;h=2415760185f879bcddfba0c20c1ade5d93ab449f;hb=cb3c15c6ac05289a612b1053102fd6f7442d9a40;hp=1d6cb98db32952e097f86667f005c55c5bd3b58d;hpb=4b846088d0ffe4f979b145ec2af821922bd5c7af;p=perl%2Fmodules%2FSub-Nary.git diff --git a/Nary.xs b/Nary.xs index 1d6cb98..2415760 100644 --- a/Nary.xs +++ b/Nary.xs @@ -33,6 +33,42 @@ CODE: ST(0) = sv_2mortal(newSVuv(o == NULL)); XSRETURN(1); +void +zero(SV *sv) +PROTOTYPE: $ +PREINIT: + HV *hv; + IV res; +CODE: + if (!SvOK(sv)) + XSRETURN_IV(1); + if (!SvROK(sv)) { + res = SvNOK(sv) ? SvNV(sv) == 0.0 : SvUV(sv) == 0; + XSRETURN_IV(res); + } + hv = (HV *) SvRV(sv); + res = hv_exists(hv, "0", 1) && hv_iterinit(hv) == 1; + XSRETURN_IV(res); + +void +count(SV *sv) +PROTOTYPE: $ +PREINIT: + HV *hv; + HE *key; + NV c = 0; +CODE: + if (!SvOK(sv)) + XSRETURN_IV(0); + if (!SvROK(sv)) + XSRETURN_IV(1); + hv = (HV *) SvRV(sv); + hv_iterinit(hv); + while (key = hv_iternext(hv)) { + c += SvNV(HeVAL(key)); + } + XSRETURN_NV(c); + void scalops() PROTOTYPE: