Home | History | Annotate | Download | only in reflect
      1 /*
      2  *  Licensed to the Apache Software Foundation (ASF) under one or more
      3  *  contributor license agreements.  See the NOTICE file distributed with
      4  *  this work for additional information regarding copyright ownership.
      5  *  The ASF licenses this file to You under the Apache License, Version 2.0
      6  *  (the "License"); you may not use this file except in compliance with
      7  *  the License.  You may obtain a copy of the License at
      8  *
      9  *     http://www.apache.org/licenses/LICENSE-2.0
     10  *
     11  *  Unless required by applicable law or agreed to in writing, software
     12  *  distributed under the License is distributed on an "AS IS" BASIS,
     13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     14  *  See the License for the specific language governing permissions and
     15  *  limitations under the License.
     16  */
     17 
     18 package java.lang.reflect;
     19 
     20 /**
     21  * This class provides static methods to decode class and member modifiers.
     22  *
     23  * @see Class#getModifiers()
     24  * @see Member#getModifiers()
     25  */
     26 public class Modifier {
     27 
     28     /**
     29      * The {@code int} value representing the {@code public} modifier.
     30      */
     31     public static final int PUBLIC = 0x1;
     32 
     33     /**
     34      * The {@code int} value representing the {@code private} modifier.
     35      */
     36     public static final int PRIVATE = 0x2;
     37 
     38     /**
     39      * The {@code int} value representing the {@code protected} modifier.
     40      */
     41     public static final int PROTECTED = 0x4;
     42 
     43     /**
     44      * The {@code int} value representing the {@code static} modifier.
     45      */
     46     public static final int STATIC = 0x8;
     47 
     48     /**
     49      * The {@code int} value representing the {@code final} modifier.
     50      */
     51     public static final int FINAL = 0x10;
     52 
     53     /**
     54      * The {@code int} value representing the {@code synchronized} modifier.
     55      */
     56     public static final int SYNCHRONIZED = 0x20;
     57 
     58     /**
     59      * The {@code int} value representing the {@code volatile} modifier.
     60      */
     61     public static final int VOLATILE = 0x40;
     62 
     63     /**
     64      * The {@code int} value representing the {@code transient} modifier.
     65      */
     66     public static final int TRANSIENT = 0x80;
     67 
     68     /**
     69      * The {@code int} value representing the {@code native} modifier.
     70      */
     71     public static final int NATIVE = 0x100;
     72 
     73     /**
     74      * The {@code int} value representing the {@code interface} modifier.
     75      */
     76     public static final int INTERFACE = 0x200;
     77 
     78     /**
     79      * The {@code int} value representing the {@code abstract} modifier.
     80      */
     81     public static final int ABSTRACT = 0x400;
     82 
     83     /**
     84      * The {@code int} value representing the {@code strictfp} modifier.
     85      */
     86     public static final int STRICT = 0x800;
     87 
     88     // Non-public types required by Java 5 update to class file format
     89     static final int BRIDGE = 0x40;
     90 
     91     static final int VARARGS = 0x80;
     92 
     93     /**
     94      * @hide
     95      */
     96     public static final int SYNTHETIC = 0x1000;
     97 
     98     static final int ANNOTATION = 0x2000;
     99 
    100     static final int ENUM = 0x4000;
    101 
    102     /**
    103      * Miranda methods are fabrications to reserve virtual method
    104      * table slots in abstract classes that implement interfaces
    105      * without declaring the abstract methods that the interface would
    106      * require they implement.
    107      * @hide
    108      */
    109     public static final int MIRANDA = 0x8000;
    110 
    111     /**
    112      * Dex addition to mark instance constructors and static class
    113      * initializer methods.
    114      * @hide
    115      */
    116     public static final int CONSTRUCTOR = 0x10000;
    117 
    118     /**
    119      * Constructs a new {@code Modifier} instance.
    120      */
    121     public Modifier() {
    122     }
    123 
    124     /**
    125      * Returns a mask of all the modifiers that may be applied to classes.
    126      * @since 1.7
    127      */
    128     public static int classModifiers() {
    129         return PUBLIC | PROTECTED | PRIVATE | ABSTRACT | STATIC | FINAL | STRICT;
    130     }
    131 
    132     /**
    133      * Returns a mask of all the modifiers that may be applied to constructors.
    134      * @since 1.7
    135      */
    136     public static int constructorModifiers() {
    137         return PUBLIC | PROTECTED | PRIVATE;
    138     }
    139 
    140     /**
    141      * Returns a mask of all the modifiers that may be applied to fields.
    142      * @since 1.7
    143      */
    144     public static int fieldModifiers() {
    145         return PUBLIC | PROTECTED | PRIVATE | STATIC | FINAL | TRANSIENT | VOLATILE;
    146     }
    147 
    148     /**
    149      * Returns a mask of all the modifiers that may be applied to interfaces.
    150      * @since 1.7
    151      */
    152     public static int interfaceModifiers() {
    153         return PUBLIC | PROTECTED | PRIVATE | ABSTRACT | STATIC | STRICT;
    154     }
    155 
    156     /**
    157      * Returns a mask of all the modifiers that may be applied to methods.
    158      * @since 1.7
    159      */
    160     public static int methodModifiers() {
    161         return PUBLIC | PROTECTED | PRIVATE | ABSTRACT | STATIC | FINAL | SYNCHRONIZED | NATIVE | STRICT;
    162     }
    163 
    164     /**
    165      * Returns true if the given modifiers contain {@link #ABSTRACT}.
    166      */
    167     public static boolean isAbstract(int modifiers) {
    168         return ((modifiers & ABSTRACT) != 0);
    169     }
    170 
    171     /**
    172      * Returns true if the given modifiers contain {@link #FINAL}.
    173      */
    174     public static boolean isFinal(int modifiers) {
    175         return ((modifiers & FINAL) != 0);
    176     }
    177 
    178     /**
    179      * Returns true if the given modifiers contain {@link #INTERFACE}.
    180      */
    181     public static boolean isInterface(int modifiers) {
    182         return ((modifiers & INTERFACE) != 0);
    183     }
    184 
    185     /**
    186      * Returns true if the given modifiers contain {@link #NATIVE}.
    187      */
    188     public static boolean isNative(int modifiers) {
    189         return ((modifiers & NATIVE) != 0);
    190     }
    191 
    192     /**
    193      * Returns true if the given modifiers contain {@link #PRIVATE}.
    194      */
    195     public static boolean isPrivate(int modifiers) {
    196         return ((modifiers & PRIVATE) != 0);
    197     }
    198 
    199     /**
    200      * Returns true if the given modifiers contain {@link #PROTECTED}.
    201      */
    202     public static boolean isProtected(int modifiers) {
    203         return ((modifiers & PROTECTED) != 0);
    204     }
    205 
    206     /**
    207      * Returns true if the given modifiers contain {@link #PUBLIC}.
    208      */
    209     public static boolean isPublic(int modifiers) {
    210         return ((modifiers & PUBLIC) != 0);
    211     }
    212 
    213     /**
    214      * Returns true if the given modifiers contain {@link #STATIC}.
    215      */
    216     public static boolean isStatic(int modifiers) {
    217         return ((modifiers & STATIC) != 0);
    218     }
    219 
    220     /**
    221      * Returns true if the given modifiers contain {@link #STRICT}.
    222      */
    223     public static boolean isStrict(int modifiers) {
    224         return ((modifiers & STRICT) != 0);
    225     }
    226 
    227     /**
    228      * Returns true if the given modifiers contain {@link #SYNCHRONIZED}.
    229      */
    230     public static boolean isSynchronized(int modifiers) {
    231         return ((modifiers & SYNCHRONIZED) != 0);
    232     }
    233 
    234     /**
    235      * Returns true if the given modifiers contain {@link #TRANSIENT}.
    236      */
    237     public static boolean isTransient(int modifiers) {
    238         return ((modifiers & TRANSIENT) != 0);
    239     }
    240 
    241     /**
    242      * Returns true if the given modifiers contain {@link #VOLATILE}.
    243      */
    244     public static boolean isVolatile(int modifiers) {
    245         return ((modifiers & VOLATILE) != 0);
    246     }
    247 
    248     /**
    249      * Returns true if the given modifiers contain {@link Modifier#CONSTRUCTOR}.
    250      * @hide
    251      */
    252     public static boolean isConstructor(int modifiers) {
    253         return ((modifiers & Modifier.CONSTRUCTOR) != 0);
    254     }
    255 
    256     /**
    257      * Returns a string containing the string representation of all modifiers
    258      * present in the specified modifiers. Modifiers appear in the order
    259      * specified by the Java Language Specification.
    260      */
    261     public static java.lang.String toString(int modifiers) {
    262         StringBuilder buf = new StringBuilder();
    263         if (isPublic(modifiers)) {
    264             buf.append("public ");
    265         }
    266         if (isProtected(modifiers)) {
    267             buf.append("protected ");
    268         }
    269         if (isPrivate(modifiers)) {
    270             buf.append("private ");
    271         }
    272         if (isAbstract(modifiers)) {
    273             buf.append("abstract ");
    274         }
    275         if (isStatic(modifiers)) {
    276             buf.append("static ");
    277         }
    278         if (isFinal(modifiers)) {
    279             buf.append("final ");
    280         }
    281         if (isTransient(modifiers)) {
    282             buf.append("transient ");
    283         }
    284         if (isVolatile(modifiers)) {
    285             buf.append("volatile ");
    286         }
    287         if (isSynchronized(modifiers)) {
    288             buf.append("synchronized ");
    289         }
    290         if (isNative(modifiers)) {
    291             buf.append("native ");
    292         }
    293         if (isStrict(modifiers)) {
    294             buf.append("strictfp ");
    295         }
    296         if (isInterface(modifiers)) {
    297             buf.append("interface ");
    298         }
    299         if (buf.length() == 0) {
    300             return "";
    301         }
    302         buf.setLength(buf.length() - 1);
    303         return buf.toString();
    304     }
    305 }
    306