ec zz = EC_INIT;
if (ECPT_PYCHECK(x)) { PyObject *t; t = x; x = y; y = t; }
- if (!ECPT_PYCHECK(y) || (xx = implicitmp(x)) == 0) RETURN_NOTIMPL;
+ if (!ECPT_PYCHECK(y)) RETURN_NOTIMPL;
+ if (FE_PYCHECK(x) && FE_F(x)->ops->ty == FTY_PRIME)
+ xx = F_OUT(FE_F(x), MP_NEW, FE_X(x));
+ else if ((xx = implicitmp(x)) == 0)
+ RETURN_NOTIMPL;
ec_imul(ECPT_C(y), &zz, ECPT_P(y), xx);
MP_DROP(xx);
return (ecpt_pywrap(ECPT_COBJ(y), &zz));
field *ff;
mp *xx, *yy;
- if (z != Py_None || !FE_PYCHECK(x) || (yy = implicitmp(y)) == 0)
+ if (z != Py_None || !FE_PYCHECK(x)) RETURN_NOTIMPL;
+ if (FE_PYCHECK(y) && FE_F(y)->ops->ty == FTY_PRIME)
+ yy = F_OUT(FE_F(y), MP_NEW, FE_X(y));
+ else if ((yy = implicitmp(y)) == 0)
RETURN_NOTIMPL;
ff = FE_F(x); xx = FE_X(x); MP_COPY(xx);
if (MP_NEGP(yy) && F_ZEROP(ff, xx)) ZDIVERR("division by zero");
mp *nn;
ge *z;
- if (m != Py_None || !GE_PYCHECK(x) || (nn = implicitmp(n)) == 0)
+ if (m != Py_None || !GE_PYCHECK(x)) RETURN_NOTIMPL;
+ if (FE_PYCHECK(n) && FE_F(n)->ops->ty == FTY_PRIME)
+ nn = F_OUT(FE_F(n), MP_NEW, FE_X(n));
+ else if ((nn = implicitmp(n)) == 0)
RETURN_NOTIMPL;
z = G_CREATE(GE_G(x));
G_EXP(GE_G(x), z, GE_X(x), nn);
me.assertRaises(TypeError, T.add, Q.point, R.point)
me.assertRaises(TypeError, T.mul, kk(1), Q)
me.assertEqual(Q - R, 11*P)
- #me.assertEqual(P*l(17), Q)
+ me.assertEqual(l(17)*P, Q)
+ me.assertEqual(P*l(17), Q)
## Ordering.
me.assertTrue(P == P)