diff options
author | David Brazdil <dbrazdil@google.com> | 2015-04-16 10:38:44 +0100 |
---|---|---|
committer | David Brazdil <dbrazdil@google.com> | 2015-04-16 10:40:53 +0100 |
commit | 4a3faecbe4157225a3fe83a9ef7f4992dfc9c19d (patch) | |
tree | 90cd60a8f7e39f6d160c3e24598fc898cdac3d7e /test/473-checker-inliner-constants | |
parent | 8e8bb8aab6f19ccb5b5869a632d9bc882891e17e (diff) | |
download | art-4a3faecbe4157225a3fe83a9ef7f4992dfc9c19d.zip art-4a3faecbe4157225a3fe83a9ef7f4992dfc9c19d.tar.gz art-4a3faecbe4157225a3fe83a9ef7f4992dfc9c19d.tar.bz2 |
ART: Don't duplicate null/int/long constants when inlining
Change-Id: I7e6a3393fcbbcf76b4ba2000915ba6bbbfb7c70e
Diffstat (limited to 'test/473-checker-inliner-constants')
-rw-r--r-- | test/473-checker-inliner-constants/expected.txt | 0 | ||||
-rw-r--r-- | test/473-checker-inliner-constants/info.txt | 1 | ||||
-rw-r--r-- | test/473-checker-inliner-constants/src/Main.java | 76 |
3 files changed, 77 insertions, 0 deletions
diff --git a/test/473-checker-inliner-constants/expected.txt b/test/473-checker-inliner-constants/expected.txt new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/test/473-checker-inliner-constants/expected.txt diff --git a/test/473-checker-inliner-constants/info.txt b/test/473-checker-inliner-constants/info.txt new file mode 100644 index 0000000..e8e1ffb --- /dev/null +++ b/test/473-checker-inliner-constants/info.txt @@ -0,0 +1 @@ +Test whether inliner deduplicates constants.
\ No newline at end of file diff --git a/test/473-checker-inliner-constants/src/Main.java b/test/473-checker-inliner-constants/src/Main.java new file mode 100644 index 0000000..79d89b0 --- /dev/null +++ b/test/473-checker-inliner-constants/src/Main.java @@ -0,0 +1,76 @@ +/* +* Copyright (C) 2015 The Android Open Source Project +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +public class Main { + + // CHECK-START: java.lang.Object Main.InlineNullConstant() inliner (before) + // CHECK: NullConstant + // CHECK-NOT: NullConstant + + // CHECK-START: java.lang.Object Main.InlineNullConstant() inliner (after) + // CHECK: NullConstant + // CHECK-NOT: NullConstant + + public static Object returnNullConstant(Object x) { + return null; + } + + public static Object InlineNullConstant() { + return returnNullConstant(null); + } + + // CHECK-START: int Main.InlineIntConstant() inliner (before) + // CHECK: IntConstant 42 + // CHECK-NOT: IntConstant 42 + + // CHECK-START: int Main.InlineIntConstant() inliner (after) + // CHECK: IntConstant 42 + // CHECK-NOT: IntConstant 42 + + public static int returnIntConstant(int x) { + return 42; + } + + public static int InlineIntConstant() { + return returnIntConstant(42); + } + + // CHECK-START: long Main.InlineLongConstant() inliner (before) + // CHECK: LongConstant 42 + // CHECK-NOT: LongConstant 42 + + // CHECK-START: long Main.InlineLongConstant() inliner (after) + // CHECK: LongConstant 42 + // CHECK-NOT: LongConstant 42 + + public static long returnLongConstant(long x) { + return 42L; + } + + public static long InlineLongConstant() { + return returnLongConstant(42L); + } + + public static void main(String[] args) { + if (InlineNullConstant() != null) { + throw new Error("Expected null"); + } else if (InlineIntConstant() != 42) { + throw new Error("Expected int 42"); + } else if (InlineLongConstant() != 42L) { + throw new Error("Expected long 42"); + } + } +} |