Yeah I tried this with RoboVM, but there are so many classes that needed to 
be stubbed that it turned into an endless rabbit hole, so I gave up. It may 
be a good solution for those who just have one or two problematic classes, 
though.

On Thursday, December 26, 2013 8:37:44 PM UTC-5, Colin Fleming wrote:
>
> In case anyone is interested in a workaround for this, I managed to "fix" 
> my compilation by stubbing out the problematic classes and putting the 
> stubs ahead of the real classes in the classpath when I compile. Where 
> those stubs return other objects that are required during static 
> initialisation, I create those classes with Mockito. I feel dirty all over 
> but it does work.
>
> I'm also tinkering with a fork of Clojure in the background that uses ASM 
> Types instead of Class objects. It's still a long way from done but it's 
> looking like that might provide a solution for compilation, at least. I'll 
> report back if I ever get it working.
>
>
> On 15 December 2013 14:05, Colin Fleming <colin.ma...@gmail.com<javascript:>
> > wrote:
>
>> I've just spent some time today looking at the compiler code, and 
>> unfortunately I think the answer is "no". When a symbol is imported, 
>> Clojure currently instantiates the Class object using Class.forName() and 
>> stores that in the namespace's mapping. At the point the Class is 
>> instantiated, static initializers are run. So the only way to avoid that is 
>> not instantiate the Class and store something else in the mapping. 
>>
>> Alex's suggestion above to store the string representing the class name 
>> and load the class on demand might work for REPL style development but 
>> won't work for AOT compilation since reflection is used to find fields, 
>> methods etc on the class during compilation. The only solution that I can 
>> see that would work for AOT would be to store some sort of class wrapper 
>> object which reads the class bytecode to get that information without 
>> instantiating the class.
>>
>> However both of these suggestions break a fairly fundamental assumption - 
>> that importing a class creates a mapping from its name to a Class object. I 
>> have no idea what sort of code might be out there making that assumption, 
>> but it's probably fair to assume there could be a lot of it. At some point 
>> I might look into creating a fork of Clojure I just use to AOT compile.
>>
>>
>> On 12 December 2013 03:41, Robin Heggelund Hansen 
>> <skinn...@gmail.com<javascript:>
>> > wrote:
>>
>>> Is this something that is fixable?
>>>
>>> -- 
>>> -- 
>>> 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