From 0bd86ba81d15584b0e12ce6d783e41bcd916b95f Mon Sep 17 00:00:00 2001 From: Rich Hickey Date: Sat, 1 Aug 2009 08:19:57 -0400 Subject: fix maybePrimitiveEpr to test for canEmitPrimitive --- src/jvm/clojure/lang/Compiler.java | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/jvm/clojure/lang/Compiler.java b/src/jvm/clojure/lang/Compiler.java index 6b76eb4e..6f1e88f4 100644 --- a/src/jvm/clojure/lang/Compiler.java +++ b/src/jvm/clojure/lang/Compiler.java @@ -1026,7 +1026,7 @@ static class StaticFieldExpr extends FieldExpr implements AssignableExpr{ static Class maybePrimitiveType(Expr e){ try { - if(e instanceof MaybePrimitiveExpr && e.hasJavaClass()) + if(e instanceof MaybePrimitiveExpr && e.hasJavaClass() && ((MaybePrimitiveExpr)e).canEmitPrimitive()) { Class c = e.getJavaClass(); if(Util.isPrimitive(c)) @@ -2135,8 +2135,7 @@ public static class IfExpr implements Expr{ try { - if(testExpr instanceof MaybePrimitiveExpr && testExpr.hasJavaClass() && - testExpr.getJavaClass() == boolean.class) + if(maybePrimitiveType(testExpr) == boolean.class) { ((MaybePrimitiveExpr) testExpr).emitUnboxed(C.EXPRESSION, objx, gen); gen.ifZCmp(gen.EQ, falseLabel); -- cgit v1.2.3-18-g5258