I guess I can proxy APersistentVector, but the Clojure docs [1] advise to 
use reify in favour to proxy whenever possible. My goal is to have my byte 
stream behave like a standard Clojure vector. (Parts of that stream also 
represent maps, and I'd like to do the same without loading them into 
Clojure maps, as they may be quite big.) It looks unidiomatic to me to 
resort to proxy to achieve that. Although maybe in the present case that's 
fine?

I'm just remembering that Collection is an interface and not a class, so I 
guess that's not too bad since I can add it to my reify.

[1] http://clojure.org/datatypes

Thanks,
Vincent


On Tuesday, 9 July 2013 20:40:43 UTC+2, Gary Trakhman wrote:
>
> From the lack of extending java's Collection in IPersistentVector or 
> associated interfaces, it seems like the intent is for every implementation 
> to extend (proxy) APersistentVector.  Is that sufficient for what you're 
> trying to do?  None of the methods in there are final.
>
>
> On Tue, Jul 9, 2013 at 2:32 PM, Vincent <vhenn...@gmail.com 
> <javascript:>>wrote:
>
>> Hello,
>>
>> Suppose I have a byte array representing an array of integers:
>> $ clojure-repl
>> Clojure 1.5.1
>> user=> (def v
>>   (let [a (byte-array (map byte [0 0 0 1 0 2 0 3]))]
>>     (reify clojure.lang.IPersistentVector
>>       clojure.lang.Seqable
>>       (seq [_] (for [i (range 0 (alength a) 2)]
>>                  (bit-or (bit-shift-left (aget a i) 8) (aget a (inc 
>> i))))))))
>> #'user/v
>> user=> (println v)
>> [0 1 2 3]
>> nil
>> user=> (= [0 1 2 3] v)
>> ClassCastException user$fn$reify__2 cannot be cast to 
>> java.util.Collection  clojure.lang.APersistentVector.doEquiv 
>> (APersistentVector.java:88)
>>
>> This is because doEquiv assumes that an instance of IPersistentVector 
>> also is an instance of Collection. While that may be true for standard 
>> Clojure data structures, this may not necessarily be the case for custom 
>> implementations.
>>
>> Am I really the first one to attempt something like that? Am I not 
>> supposed to write custom implementations of standard interfaces? Should 
>> that bug be raised in JIRA?
>>
>> Thanks,
>> Vincent
>>
>> -- 
>> -- 
>> You received this message because you are subscribed to the Google
>> Groups "Clojure" group.
>> To post to this group, send email to clo...@googlegroups.com<javascript:>
>> Note that posts from new members are moderated - please be patient with 
>> your first post.
>> To unsubscribe from this group, send email to
>> clojure+u...@googlegroups.com <javascript:>
>> For more options, visit this group at
>> http://groups.google.com/group/clojure?hl=en
>> --- 
>> You received this message because you are subscribed to the Google Groups 
>> "Clojure" group.
>> To unsubscribe from this group and stop receiving emails from it, send an 
>> email to clojure+u...@googlegroups.com <javascript:>.
>> For more options, visit https://groups.google.com/groups/opt_out.
>>  
>>  
>>
>
>

-- 
-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.


Reply via email to