src.org.python.modules.itertools.imap Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jython-standalone Show documentation
Show all versions of jython-standalone Show documentation
Jython is an implementation of the high-level, dynamic, object-oriented
language Python written in 100% Pure Java, and seamlessly integrated with
the Java platform. It thus allows you to run Python on any Java platform.
/* Copyright (c) Jython Developers */
package org.python.modules.itertools;
import org.python.core.Py;
import org.python.core.PyIterator;
import org.python.core.PyObject;
import org.python.core.PyTuple;
import org.python.core.PyType;
import org.python.core.Visitproc;
import org.python.expose.ExposedNew;
import org.python.expose.ExposedMethod;
import org.python.expose.ExposedType;
@ExposedType(name = "itertools.imap", base = PyObject.class, doc = imap.imap_doc)
public class imap extends PyIterator {
public static final PyType TYPE = PyType.fromClass(imap.class);
private PyIterator iter;
public static final String imap_doc =
"'map(func, *iterables) --> imap object\n\n" +
"Make an iterator that computes the function using arguments from\n" +
"each of the iterables.\tLike map() except that it returns\n" +
"an iterator instead of a list and that it stops when the shortest\n" +
"iterable is exhausted instead of filling in None for shorter\n" +
"iterables.";
public imap() {
super();
}
public imap(PyType subType) {
super(subType);
}
public imap(PyObject... args) {
super();
imap___init__(args);
}
/**
* Works as __builtin__.map()
but returns an iterator instead of a list. (Code in
* this method is based on __builtin__.map()).
*/
@ExposedNew
@ExposedMethod
final void imap___init__(PyObject[] args, String[] kwds) {
if (kwds.length > 0) {
throw Py.TypeError(String.format("imap does not take keyword arguments"));
}
imap___init__(args);
}
private void imap___init__(final PyObject[] argstar) {
if (argstar.length < 2) {
throw Py.TypeError("imap requires at least two arguments");
}
final int n = argstar.length - 1;
final PyObject func = argstar[0];
final PyObject[] iterables = new PyObject[n];
for (int j = 0; j < n; j++) {
iterables[j] = Py.iter(argstar[j + 1], "argument " + (j + 1)
+ " to imap() must support iteration");
}
iter = new PyIterator() {
PyObject[] args = new PyObject[n];
PyObject element = null;
public PyObject __iternext__() {
for (int i = 0; i < n; i++) {
if ((element = iterables[i].__iternext__()) != null) {
// collect the arguments for the func
args[i] = element;
} else {
// break iteration
return null;
}
}
if (func == Py.None) {
// if None is supplied as func we just return what's in
// the iterable(s)
if (n == 1) {
return args[0];
} else {
return new PyTuple(args.clone());
}
} else {
return func.__call__(args);
}
}
};
}
public PyObject __iternext__() {
return iter.__iternext__();
}
@ExposedMethod
@Override
public PyObject next() {
return doNext(__iternext__());
}
/* Traverseproc implementation */
@Override
public int traverse(Visitproc visit, Object arg) {
int retVal = super.traverse(visit, arg);
if (retVal != 0) {
return retVal;
}
return iter != null ? visit.visit(iter, arg) : 0;
}
@Override
public boolean refersDirectlyTo(PyObject ob) {
return ob != null && (iter == ob || super.refersDirectlyTo(ob));
}
}