Mercurial > hg > icedrobot > daneel
view src/test/java/org/icedrobot/daneel/rewriter/AnnotationParamTest.java @ 125:0355dd717a24
Fixed enumerations as annotation parameters.
* dex/DexAnnotationVisitor.java (visitEnum): Added new interface method.
* dex/EncodedValue.java (parse): Decode encoded enumeration values.
* rewriter/DexRewriter.java (AnnotationRewriter): Adapted to above change.
* rewriter/AnnotationParamTest.java: New test case for annotation parameters.
author | Michael Starzinger <michi@complang.tuwien.ac.at> |
---|---|
date | Mon, 11 Apr 2011 11:05:15 +0200 |
parents | |
children |
line wrap: on
line source
/* * Daneel - Dalvik to Java bytecode compiler * Copyright (C) 2011 IcedRobot team * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * This file is subject to the "Classpath" exception: * * Linking this library statically or dynamically with other modules is * making a combined work based on this library. Thus, the terms and * conditions of the GNU General Public License cover the whole * combination. * * As a special exception, the copyright holders of this library give you * permission to link this library with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under terms * of your choice, provided that you also meet, for each linked independent * module, the terms and conditions of the license of that module. An * independent module is a module which is not derived from or based on * this library. If you modify this library, you may extend this exception * to your version of the library, but you are not obligated to do so. If * you do not wish to do so, delete this exception statement from your * version. */ package org.icedrobot.daneel.rewriter; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertSame; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.reflect.Field; import org.icedrobot.daneel.DexifyingRunner; import org.junit.Test; import org.junit.runner.RunWith; @RunWith(DexifyingRunner.class) public class AnnotationParamTest { @Test public void testEnumParam() throws Exception { Field f = DEXCode.class.getField("fieldEnum"); TestEnumAnnotation a = f.getAnnotation(TestEnumAnnotation.class); assertNotNull(a); assertSame(TestEnumeration.CONST_B, a.value()); } private static enum TestEnumeration { CONST_A, CONST_B; }; @Retention(RetentionPolicy.RUNTIME) private static @interface TestEnumAnnotation { TestEnumeration value(); }; // Keep this class named "DEXCode" to push it through Daneel. public static class DEXCode { @TestEnumAnnotation(TestEnumeration.CONST_B) public int fieldEnum; }; }