rt/vm/src/test/java/org/apidesign/vm4brwsr/Classes.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Wed, 25 Jun 2014 23:43:51 +0200
branchdefprop
changeset 1637 4156b1bd4b82
parent 1636 eb97a082741b
child 1727 86e61729f754
permissions -rw-r--r--
Don't list overriden Object's methods twice
     1 /**
     2  * Back 2 Browser Bytecode Translator
     3  * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
     4  *
     5  * This program is free software: you can redistribute it and/or modify
     6  * it under the terms of the GNU General Public License as published by
     7  * the Free Software Foundation, version 2 of the License.
     8  *
     9  * This program is distributed in the hope that it will be useful,
    10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
    11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    12  * GNU General Public License for more details.
    13  *
    14  * You should have received a copy of the GNU General Public License
    15  * along with this program. Look for COPYING file in the top folder.
    16  * If not, see http://opensource.org/licenses/GPL-2.0.
    17  */
    18 package org.apidesign.vm4brwsr;
    19 
    20 import java.io.IOException;
    21 import java.io.Serializable;
    22 import java.lang.annotation.Annotation;
    23 import java.lang.annotation.Retention;
    24 import java.lang.annotation.RetentionPolicy;
    25 import java.lang.reflect.Method;
    26 import java.net.MalformedURLException;
    27 import org.apidesign.bck2brwsr.core.JavaScriptBody;
    28 
    29 /**
    30  *
    31  * @author Jaroslav Tulach <jtulach@netbeans.org>
    32  */
    33 @ClassesMarker(number = 10, nicknames = { "Ten", "Deset" }, count = ClassesMarker.E.TWO, subs = {
    34     @ClassesMarker.Anno(Integer.SIZE),
    35     @ClassesMarker.Anno(Integer.MIN_VALUE)
    36 })
    37 @ClassesNamer(name = "my text", anno = @ClassesMarker.Anno(333))
    38 public class Classes {
    39     public static String nameOfIO() {
    40         return nameFor(IOException.class);
    41     }
    42     
    43     private static String nameFor(Class<?> c) {
    44         return c.getName();
    45     }
    46     
    47     private static final Class<?> PRELOAD = Runnable.class;
    48     
    49     public static boolean isInterface(String s) throws ClassNotFoundException {
    50         return Class.forName(s).isInterface();
    51     }
    52     
    53     public static boolean equalsClassesOfExceptions() {
    54         return MalformedURLException.class.getSuperclass() == IOException.class;
    55     }
    56     public static boolean differenceInClasses() {
    57         Class<?> c1 = MalformedURLException.class;
    58         Class<?> c2 = IOException.class;
    59         return c1 != c2;
    60     }
    61     
    62     public static String classForInstance() {
    63         return new IOException().getClass().getName().toString();
    64     }
    65     
    66     @ClassesMarker(number = 1, nicknames = { "One", "Jedna" } )
    67     public static String name() {
    68         return IOException.class.getName().toString();
    69     }
    70     public static String simpleName() {
    71         return IOException.class.getSimpleName();
    72     }
    73     public static String canonicalName() {
    74         return IOException.class.getCanonicalName();
    75     }
    76     
    77     public static String objectName() throws NoSuchMethodException {
    78         return IOException.class.getMethod("wait").getDeclaringClass().getName();
    79     }
    80     
    81     public static boolean newInstance() throws Exception {
    82         IOException ioe = IOException.class.newInstance();
    83         if (ioe instanceof IOException) {
    84             return ioe.getClass() == IOException.class;
    85         }
    86         throw new IllegalStateException("Not a subtype: " + ioe);
    87     }
    88     public static String newInstanceNoPubConstructor() throws Exception {
    89         try {
    90             Float f = Float.class.newInstance();
    91             return "wrong, can't instantiate: " + f;
    92         } catch (Exception ex) {
    93             return (ex.getClass().getName() + ":" + ex.getMessage()).toString().toString();
    94         }
    95     }
    96     public static int getMarker() {
    97         if (!Classes.class.isAnnotationPresent(ClassesMarker.class)) {
    98             return -2;
    99         }
   100         ClassesMarker cm = Classes.class.getAnnotation(ClassesMarker.class);
   101         assert cm instanceof Object : "Is object " + cm;
   102         assert cm instanceof Annotation : "Is annotation " + cm;
   103         assert !((Object)cm instanceof Class) : "Is not Class " + cm;
   104         return cm == null ? -1 : cm.number();
   105     }
   106     public static String getMarkerNicknames() {
   107         ClassesMarker cm = Classes.class.getAnnotation(ClassesMarker.class);
   108         if (cm == null) {
   109             return null;
   110         }
   111         
   112         final Object[] arr = cm.nicknames();
   113         assert arr instanceof Object[] : "Instance of Object array: " + arr;
   114         assert arr instanceof String[] : "Instance of String array: " + arr;
   115         assert !(arr instanceof Integer[]) : "Not instance of Integer array: " + arr;
   116         
   117         StringBuilder sb = new StringBuilder();
   118         for (String s : cm.nicknames()) {
   119             sb.append(s).append("\n");
   120         }
   121         return sb.toString().toString();
   122     }
   123 
   124     static String listObject(boolean string, String prefix) {
   125         final Class<?> c = string ? String.class : Object.class;
   126         StringBuilder sb = new StringBuilder();
   127         for (Method m : c.getMethods()) {
   128             final String n = m.getName();
   129             if (n.startsWith(prefix)) {
   130                 sb.append(n).append("\n");
   131             }
   132         }
   133         return sb.toString().toString();
   134     }
   135     @Retention(RetentionPolicy.CLASS)
   136     @interface Ann {
   137     }
   138     
   139     public static String getRetention() throws Exception {
   140         Retention r = Ann.class.getAnnotation(Retention.class);
   141         assert r != null : "Annotation is present";
   142         assert r.value() == RetentionPolicy.CLASS : "Policy value is OK: " + r.value();
   143         return r.annotationType().getName();
   144     }
   145     public static String getMarkerE() {
   146         ClassesMarker cm = Classes.class.getAnnotation(ClassesMarker.class);
   147         if (cm == null) {
   148             return null;
   149         }
   150         return cm.count().name();
   151     }
   152     public static String getNamer(boolean direct) {
   153         if (direct) {
   154             ClassesNamer cm = Classes.class.getAnnotation(ClassesNamer.class);
   155             return cm == null ? null : cm.name();
   156         }
   157         for (Annotation a : Classes.class.getAnnotations()) {
   158             if (a instanceof ClassesNamer) {
   159                 return ((ClassesNamer)a).name();
   160             }
   161         }
   162         return null;
   163     }
   164     public static int getInnerNamer() {
   165         ClassesNamer cm = Classes.class.getAnnotation(ClassesNamer.class);
   166         assert cm != null : "ClassesNamer is present";
   167         return cm.anno().value();
   168     }
   169     public static int getInnerNamers() {
   170         ClassesMarker cm = Classes.class.getAnnotation(ClassesMarker.class);
   171         assert cm != null : "ClassesNamer is present";
   172         int sum = 0;
   173         for (ClassesMarker.Anno anno : cm.subs()) {
   174             sum += anno.value();
   175         }
   176         return sum;
   177     }
   178     
   179     public static String intType() {
   180         return Integer.TYPE.getName();
   181     }
   182     
   183     public static int primitive() {
   184         return 1;
   185     }
   186     public static boolean primitiveB() {
   187         return true;
   188     }
   189     
   190     public static String primitiveType(String method) throws Exception {
   191         return reflectiveMethodCall(false, method).getClass().getName();
   192     }
   193     
   194     @JavaScriptBody(args = "msg", body = "throw msg;")
   195     private static native void thrw(String msg);
   196     
   197     public static Object reflectiveMethodCall(boolean direct, String mn) throws Exception {
   198         Method find = null;
   199         StringBuilder sb = new StringBuilder();
   200         if (!direct) {
   201             final Class<? extends Annotation> v = ClassesMarker.class;
   202             for (Method m : Classes.class.getMethods()) {
   203                 sb.append("\n").append(m.getName());
   204                 if (mn != null) {
   205                     if (m.getName().equals(mn)) {
   206                         find = m;
   207                         break;
   208                     }
   209                 } else {
   210                     if (m.getAnnotation(v) != null) {
   211                         find = m;
   212                         break;
   213                     }
   214                 }
   215             }
   216         } else {
   217             find = Classes.class.getMethod(mn);
   218         }
   219         if (find == null) {
   220             thrw(sb.toString());
   221             throw new NullPointerException(sb.toString());
   222         }
   223         return find.invoke(null);
   224     }
   225     
   226     public static int reflectiveSum(int a, int b) throws Exception {
   227         Method m = StaticMethod.class.getMethod("sum", int.class, int.class);
   228         return (int) m.invoke(null, a, b);
   229     }
   230     
   231     private abstract class Application {
   232         public abstract int getID();
   233     }
   234 
   235     private class MyApplication extends Application {
   236         @Override
   237         public int getID() {
   238             return 1;
   239         }
   240     }
   241 
   242     public static boolean isClassAssignable() {
   243         return Application.class.isAssignableFrom(MyApplication.class);
   244     }
   245     
   246     public static String valueEnum(String v) {
   247         return ClassesMarker.E.valueOf(v).toString();
   248     }
   249     
   250     public static String typeOfFn() {
   251         return fn().getClass().getName();
   252     }
   253     
   254     @JavaScriptBody(args = {  }, body = "return function() { alert('x'); };")
   255     private native static Object fn();
   256     
   257     public static boolean instanceOfSuperInterface() {
   258         Object obj = new SuperSerial() {
   259         };
   260         return obj instanceof Serializable;
   261     }
   262     
   263     private static interface SuperSerial extends Serializable {
   264     }
   265 }