langtools/test/tools/apt/mirror/declaration/ConstExpr.java
author lana
Tue, 01 Jun 2010 14:17:38 -0700
changeset 5597 ab490f66d2cf
parent 5520 86e4b9a9da40
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1652
diff changeset
     2
 * Copyright (c) 2004, 2008, Oracle and/or its affiliates. All rights reserved.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
06bc494ca11e Initial load
duke
parents:
diff changeset
     4
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
06bc494ca11e Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
06bc494ca11e Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
06bc494ca11e Initial load
duke
parents:
diff changeset
     8
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
06bc494ca11e Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
06bc494ca11e Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
06bc494ca11e Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
06bc494ca11e Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
06bc494ca11e Initial load
duke
parents:
diff changeset
    14
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
06bc494ca11e Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
06bc494ca11e Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
06bc494ca11e Initial load
duke
parents:
diff changeset
    18
 *
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1652
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1652
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1652
diff changeset
    21
 * questions.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    22
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    23
06bc494ca11e Initial load
duke
parents:
diff changeset
    24
06bc494ca11e Initial load
duke
parents:
diff changeset
    25
/*
06bc494ca11e Initial load
duke
parents:
diff changeset
    26
 * @test
06bc494ca11e Initial load
duke
parents:
diff changeset
    27
 * @bug 5027675 5048535
06bc494ca11e Initial load
duke
parents:
diff changeset
    28
 * @summary Tests FieldDeclaration.getConstantExpression method
06bc494ca11e Initial load
duke
parents:
diff changeset
    29
 * @library ../../lib
06bc494ca11e Initial load
duke
parents:
diff changeset
    30
 * @compile -source 1.5 ConstExpr.java
1467
290837884931 6749967: regression tests for apt should be same-vm friendly
jjg
parents: 10
diff changeset
    31
 * @run main/othervm ConstExpr
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    32
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
06bc494ca11e Initial load
duke
parents:
diff changeset
    34
06bc494ca11e Initial load
duke
parents:
diff changeset
    35
import java.math.RoundingMode;
06bc494ca11e Initial load
duke
parents:
diff changeset
    36
import java.util.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    37
06bc494ca11e Initial load
duke
parents:
diff changeset
    38
import com.sun.mirror.declaration.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    39
import com.sun.mirror.type.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    40
import com.sun.mirror.util.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    41
06bc494ca11e Initial load
duke
parents:
diff changeset
    42
import static java.math.RoundingMode.UP;
06bc494ca11e Initial load
duke
parents:
diff changeset
    43
06bc494ca11e Initial load
duke
parents:
diff changeset
    44
import static com.sun.mirror.util.DeclarationVisitors.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    45
06bc494ca11e Initial load
duke
parents:
diff changeset
    46
06bc494ca11e Initial load
duke
parents:
diff changeset
    47
public class ConstExpr extends Tester {
06bc494ca11e Initial load
duke
parents:
diff changeset
    48
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
    public static void main(String[] args) {
06bc494ca11e Initial load
duke
parents:
diff changeset
    50
        (new ConstExpr()).run();
06bc494ca11e Initial load
duke
parents:
diff changeset
    51
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
    52
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
    // Declarations used by tests
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
    public static final byte B = (byte) 0xBE;
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
    public static final short S = (short) 32767;
06bc494ca11e Initial load
duke
parents:
diff changeset
    58
    public static final int I = -4;
06bc494ca11e Initial load
duke
parents:
diff changeset
    59
    public static final long l = 4294967296L;
06bc494ca11e Initial load
duke
parents:
diff changeset
    60
    public static final float f = 3.5f;
06bc494ca11e Initial load
duke
parents:
diff changeset
    61
    public static final double PI = Math.PI;
06bc494ca11e Initial load
duke
parents:
diff changeset
    62
    public static final char C = 'C';
06bc494ca11e Initial load
duke
parents:
diff changeset
    63
    public static final String STR = "cheese";
06bc494ca11e Initial load
duke
parents:
diff changeset
    64
06bc494ca11e Initial load
duke
parents:
diff changeset
    65
    public static final char SMILEY = '\u263A';
06bc494ca11e Initial load
duke
parents:
diff changeset
    66
    public static final String TWOLINES = "ab\ncd";
06bc494ca11e Initial load
duke
parents:
diff changeset
    67
06bc494ca11e Initial load
duke
parents:
diff changeset
    68
    public static final double D1 = Double.POSITIVE_INFINITY;
06bc494ca11e Initial load
duke
parents:
diff changeset
    69
    public static final double D2 = Double.NEGATIVE_INFINITY;
06bc494ca11e Initial load
duke
parents:
diff changeset
    70
    public static final double D3 = Double.NaN;
06bc494ca11e Initial load
duke
parents:
diff changeset
    71
    public static final float  F1 = Float.POSITIVE_INFINITY;
06bc494ca11e Initial load
duke
parents:
diff changeset
    72
    public static final float  F2 = Float.NEGATIVE_INFINITY;
06bc494ca11e Initial load
duke
parents:
diff changeset
    73
    public static final float  F3 = Float.NaN;
06bc494ca11e Initial load
duke
parents:
diff changeset
    74
06bc494ca11e Initial load
duke
parents:
diff changeset
    75
    public static final String NOSTR = null;    // not a compile-time constant
06bc494ca11e Initial load
duke
parents:
diff changeset
    76
    public static final RoundingMode R = UP;    // not a compile-time constant
06bc494ca11e Initial load
duke
parents:
diff changeset
    77
06bc494ca11e Initial load
duke
parents:
diff changeset
    78
06bc494ca11e Initial load
duke
parents:
diff changeset
    79
    @Test(result={
06bc494ca11e Initial load
duke
parents:
diff changeset
    80
              "0xbe",
06bc494ca11e Initial load
duke
parents:
diff changeset
    81
              "32767",
06bc494ca11e Initial load
duke
parents:
diff changeset
    82
              "-4",
06bc494ca11e Initial load
duke
parents:
diff changeset
    83
              "4294967296L",
06bc494ca11e Initial load
duke
parents:
diff changeset
    84
              "3.5f",
06bc494ca11e Initial load
duke
parents:
diff changeset
    85
              "3.141592653589793",
06bc494ca11e Initial load
duke
parents:
diff changeset
    86
              "'C'",
06bc494ca11e Initial load
duke
parents:
diff changeset
    87
              "\"cheese\"",
06bc494ca11e Initial load
duke
parents:
diff changeset
    88
06bc494ca11e Initial load
duke
parents:
diff changeset
    89
              "'\\u263a'",
06bc494ca11e Initial load
duke
parents:
diff changeset
    90
              "\"ab\\ncd\"",
06bc494ca11e Initial load
duke
parents:
diff changeset
    91
06bc494ca11e Initial load
duke
parents:
diff changeset
    92
              "1.0/0.0",
06bc494ca11e Initial load
duke
parents:
diff changeset
    93
              "-1.0/0.0",
06bc494ca11e Initial load
duke
parents:
diff changeset
    94
              "0.0/0.0",
06bc494ca11e Initial load
duke
parents:
diff changeset
    95
              "1.0f/0.0f",
06bc494ca11e Initial load
duke
parents:
diff changeset
    96
              "-1.0f/0.0f",
06bc494ca11e Initial load
duke
parents:
diff changeset
    97
              "0.0f/0.0f",
06bc494ca11e Initial load
duke
parents:
diff changeset
    98
06bc494ca11e Initial load
duke
parents:
diff changeset
    99
              "null",
06bc494ca11e Initial load
duke
parents:
diff changeset
   100
              "null"
06bc494ca11e Initial load
duke
parents:
diff changeset
   101
          },
06bc494ca11e Initial load
duke
parents:
diff changeset
   102
          ordered=true)
06bc494ca11e Initial load
duke
parents:
diff changeset
   103
    Collection<String> getConstantExpression() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   104
        final Collection<String> res = new ArrayList<String>();
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
06bc494ca11e Initial load
duke
parents:
diff changeset
   106
        thisClassDecl.accept(
06bc494ca11e Initial load
duke
parents:
diff changeset
   107
            DeclarationVisitors.getSourceOrderDeclarationScanner(
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
                NO_OP,
06bc494ca11e Initial load
duke
parents:
diff changeset
   109
                new SimpleDeclarationVisitor() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   110
                    public void visitFieldDeclaration(FieldDeclaration f) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   111
                        res.add(f.getConstantExpression());
06bc494ca11e Initial load
duke
parents:
diff changeset
   112
                    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   113
                }));
06bc494ca11e Initial load
duke
parents:
diff changeset
   114
        return res;
06bc494ca11e Initial load
duke
parents:
diff changeset
   115
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   116
}