La función seq
ahora hace sólo esto:
(. clojure.lang.RT (seq coll))
En RT.java
en la última versión de Clojure, encontrará:
static public ISeq seq(Object coll){
if(coll instanceof ASeq)
return (ASeq) coll;
else if(coll instanceof LazySeq)
return ((LazySeq) coll).seq();
else
return seqFrom(coll);
}
static ISeq seqFrom(Object coll){
if(coll instanceof Seqable)
return ((Seqable) coll).seq();
else if(coll == null)
return null;
else if(coll instanceof Iterable)
return IteratorSeq.create(((Iterable) coll).iterator());
else if(coll.getClass().isArray())
return ArraySeq.createFromObject(coll);
else if(coll instanceof CharSequence)
return StringSeq.create((CharSequence) coll);
else if(coll instanceof Map)
return seq(((Map) coll).entrySet());
else {
Class c = coll.getClass();
Class sc = c.getSuperclass();
throw new IllegalArgumentException("Don't know how to create ISeq from: " + c.getName());
}
}
Un ASeq
o una LazySeq
ya es un ss. Un Seqable
es algo que sabe cómo devolver un seq de sí mismo.
Eso deja cosas como las clases de núcleo de Java, que deberían ser posibles pero que Clojure no puede modificar para agregar un método seq
. Actualmente, estos están codificados en esta lista. No me sorprendería si la implementación cambiara algún día, tal vez usando protocolos para extender las clases centrales de Java.
@kotarak gracias por arreglar el enlace :) –
Creo que esto se ha movido ... ¿alguna actualización sobre dónde está? – jayunit100
En la versión actual de Clojure (1.5) seqable? Actualmente vive en clojure.core.incubator (repo @ https://github.com/clojure/core.incubator) –