From 1b5b717f548930f171846c0df3a53b8c235316b0 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Fri, 27 May 2016 17:12:09 +0300 Subject: [PATCH 001/125] 8156469: [JITtester] Difference in generated golden output when run with Jigsaw build Reviewed-by: vlivanov --- .../lib/jittester/jtreg/JitTesterDriver.java | 17 ++---- .../test/lib/jittester/utils/FixedTrees.java | 61 ++++++++++++------- 2 files changed, 44 insertions(+), 34 deletions(-) diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java index ca04131baed..d6b7db9ee41 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java @@ -56,24 +56,19 @@ public class JitTesterDriver { Pattern splitOut = Pattern.compile("\\n"); // tests use \n only in stdout Pattern splitErr = Pattern.compile("\\r?\\n"); // can handle both \r\n and \n Path testDir = Paths.get(Utils.TEST_SRC); - String goldOut = formatOutput(streamGoldFile(testDir, args[0], "out"), s -> true); - String anlzOut = formatOutput(Arrays.stream(splitOut.split(oa.getStdout())), s -> true); + String goldOut = formatOutput(streamGoldFile(testDir, args[0], "out")); + String anlzOut = formatOutput(Arrays.stream(splitOut.split(oa.getStdout()))); Asserts.assertEQ(anlzOut, goldOut, "Actual stdout isn't equal to golden one"); - // TODO: add a comment why we skip such lines - Predicate notStartWhitespaces = s -> !(s.startsWith("\t") || s.startsWith(" ")); - String goldErr = formatOutput(streamGoldFile(testDir, args[0], "err"), notStartWhitespaces); - String anlzErr = formatOutput(Arrays.stream(splitErr.split(oa.getStderr())), - notStartWhitespaces); + String goldErr = formatOutput(streamGoldFile(testDir, args[0], "err")); + String anlzErr = formatOutput(Arrays.stream(splitErr.split(oa.getStderr()))); Asserts.assertEQ(anlzErr, goldErr, "Actual stderr isn't equal to golden one"); int exitValue = Integer.parseInt(streamGoldFile(testDir, args[0], "exit").findFirst().get()); oa.shouldHaveExitValue(exitValue); } - private static String formatOutput(Stream stream, Predicate predicate) { - String result = stream - .filter(predicate) - .collect(Collectors.joining(Utils.NEW_LINE)); + private static String formatOutput(Stream stream) { + String result = stream.collect(Collectors.joining(Utils.NEW_LINE)); if (result.length() > 0) { result += Utils.NEW_LINE; } diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/FixedTrees.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/FixedTrees.java index a2c656c75d2..1f25d4a3d41 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/FixedTrees.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/FixedTrees.java @@ -23,9 +23,11 @@ package jdk.test.lib.jittester.utils; +import java.util.Arrays; import java.util.ArrayList; import java.util.LinkedList; import java.util.List; + import jdk.test.lib.jittester.BinaryOperator; import jdk.test.lib.jittester.Block; import jdk.test.lib.jittester.CatchBlock; @@ -60,6 +62,8 @@ import jdk.test.lib.jittester.types.TypeArray; import jdk.test.lib.jittester.types.TypeKlass; public class FixedTrees { + private static final Literal EOL = new Literal("\n", TypeList.STRING); + public static FunctionDefinition printVariablesAsFunction(PrintVariables node) { TypeKlass owner = node.getOwner(); @@ -72,7 +76,6 @@ public class FixedTrees { List vars = node.getVars(); TypeKlass printerKlass = new TypeKlass(Printer.class.getName()); - Literal EOL = new Literal("\n", TypeList.STRING); VariableInfo thisInfo = new VariableInfo("this", node.getOwner(), node.getOwner(), VariableInfo.LOCAL | VariableInfo.INITIALIZED); @@ -109,6 +112,7 @@ public class FixedTrees { FunctionInfo toStringInfo = new FunctionInfo("toString", owner, TypeList.STRING, 0L, FunctionInfo.PUBLIC, thisInfo); return new FunctionDefinition(toStringInfo, new ArrayList<>(), block, new Return(resultVar)); } + public static FunctionDefinition generateMainOrExecuteMethod(TypeKlass owner, boolean isMain) { Nothing nothing = new Nothing(); ArrayList testCallNodeContent = new ArrayList<>(); @@ -149,39 +153,50 @@ public class FixedTrees { List throwables = new ArrayList<>(); throwables.add(throwableKlass); - VariableInfo exInfo = new VariableInfo("ex", owner, throwableKlass, - VariableInfo.LOCAL | VariableInfo.INITIALIZED); - FunctionInfo printStackTraceInfo = new FunctionInfo("printStackTrace", throwableKlass, - TypeList.VOID, 0, FunctionInfo.PUBLIC, exInfo); - Function printStackTraceCall = new Function(throwableKlass, printStackTraceInfo, null); - printStackTraceCall.addChild(new LocalVariable(exInfo)); - ArrayList printStackTraceCallBlockContent = new ArrayList<>(); - // { ex.printStackTrace(); } - printStackTraceCallBlockContent.add(new Statement(printStackTraceCall, true)); - - Block printStackTraceCallBlock = new Block(owner, TypeList.VOID, printStackTraceCallBlockContent, 3); - List catchBlocks1 = new ArrayList<>(); - catchBlocks1.add(new CatchBlock(printStackTraceCallBlock, throwables, 3)); - List catchBlocks2 = new ArrayList<>(); - catchBlocks2.add(new CatchBlock(printStackTraceCallBlock, throwables, 3)); - List catchBlocks3 = new ArrayList<>(); - catchBlocks3.add(new CatchBlock(printStackTraceCallBlock, throwables, 2)); - - TryCatchBlock tryCatch1 = new TryCatchBlock(tryNode, nothing, catchBlocks1, 3); TypeKlass printStreamKlass = new TypeKlass("java.io.PrintStream"); - TypeKlass systemKlass = new TypeKlass("java.lang.System"); - FunctionInfo systemOutPrintInfo = new FunctionInfo("print", printStreamKlass, + FunctionInfo printInfo = new FunctionInfo("print", printStreamKlass, TypeList.VOID, 0, FunctionInfo.PUBLIC, new VariableInfo("this", owner, printStreamKlass, VariableInfo.LOCAL | VariableInfo.INITIALIZED), new VariableInfo("t", owner, TypeList.OBJECT, VariableInfo.LOCAL | VariableInfo.INITIALIZED)); + TypeKlass systemKlass = new TypeKlass("java.lang.System"); + StaticMemberVariable systemErrVar = new StaticMemberVariable(owner, + new VariableInfo("err", systemKlass, printStreamKlass, VariableInfo.STATIC | VariableInfo.PUBLIC)); + + LocalVariable exVar = new LocalVariable( + new VariableInfo("ex", owner, throwableKlass, VariableInfo.LOCAL | VariableInfo.INITIALIZED)); + TypeKlass classKlass = new TypeKlass("java.lang.Class"); + FunctionInfo getClassInfo = new FunctionInfo("getClass", TypeList.OBJECT, + classKlass, 0, FunctionInfo.PUBLIC, + new VariableInfo("this", owner, TypeList.OBJECT, VariableInfo.LOCAL | VariableInfo.INITIALIZED)); + Function getClass = new Function(TypeList.OBJECT, getClassInfo, Arrays.asList(exVar)); + FunctionInfo getNameInfo = new FunctionInfo("getName", classKlass, + TypeList.STRING, 0, FunctionInfo.PUBLIC, + new VariableInfo("this", owner, TypeList.OBJECT, VariableInfo.LOCAL | VariableInfo.INITIALIZED)); + Function getName = new Function(classKlass, getNameInfo, Arrays.asList(getClass)); + ArrayList printExceptionBlockContent = new ArrayList<>(); + // { System.err.print(ex.getClass().getName()); System.err.print("\n"); } + printExceptionBlockContent.add(new Statement( + new Function(printStreamKlass, printInfo, Arrays.asList(systemErrVar, getName)), true)); + printExceptionBlockContent.add(new Statement( + new Function(printStreamKlass, printInfo, Arrays.asList(systemErrVar, EOL)), true)); + + Block printExceptionBlock = new Block(owner, TypeList.VOID, printExceptionBlockContent, 3); + List catchBlocks1 = new ArrayList<>(); + catchBlocks1.add(new CatchBlock(printExceptionBlock, throwables, 3)); + List catchBlocks2 = new ArrayList<>(); + catchBlocks2.add(new CatchBlock(printExceptionBlock, throwables, 3)); + List catchBlocks3 = new ArrayList<>(); + catchBlocks3.add(new CatchBlock(printExceptionBlock, throwables, 2)); + + TryCatchBlock tryCatch1 = new TryCatchBlock(tryNode, nothing, catchBlocks1, 3); List printArgs = new ArrayList<>(); VariableInfo systemOutInfo = new VariableInfo("out", systemKlass, printStreamKlass, VariableInfo.STATIC | VariableInfo.PUBLIC); StaticMemberVariable systemOutVar = new StaticMemberVariable(owner, systemOutInfo); printArgs.add(systemOutVar); printArgs.add(tVar); - Function print = new Function(printStreamKlass, systemOutPrintInfo, printArgs); + Function print = new Function(printStreamKlass, printInfo, printArgs); ArrayList printBlockContent = new ArrayList<>(); printBlockContent.add(new Statement(print, true)); Block printBlock = new Block(owner, TypeList.VOID, printBlockContent, 3); From 05540f90da5288a7f665f2e15982af5f169b5d3c Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Fri, 27 May 2016 17:12:10 +0300 Subject: [PATCH 002/125] 8157821: [JITtester] OptionResolver and LiteralFactory use deprecated c-tors Reviewed-by: kvn --- .../src/jdk/test/lib/jittester/factories/LiteralFactory.java | 4 ++-- .../src/jdk/test/lib/jittester/utils/OptionResolver.java | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/LiteralFactory.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/LiteralFactory.java index 8bdd2c4e38a..e5f213fb8d9 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/LiteralFactory.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/LiteralFactory.java @@ -51,13 +51,13 @@ class LiteralFactory extends Factory { } else if (resultType.equals(TypeList.LONG)) { literal = new Literal((long) (PseudoRandom.random() * Long.MAX_VALUE), TypeList.LONG); } else if (resultType.equals(TypeList.FLOAT)) { - literal = new Literal(new Float(String.format( + literal = new Literal(Float.valueOf(String.format( (Locale) null, "%." + ProductionParams.floatingPointPrecision.value() + "EF", (float) PseudoRandom.random() * Float.MAX_VALUE)), TypeList.FLOAT); } else if (resultType.equals(TypeList.DOUBLE)) { - literal = new Literal(new Double(String.format( + literal = new Literal(Double.valueOf(String.format( (Locale) null, "%." + 2 * ProductionParams.floatingPointPrecision.value() + "E", PseudoRandom.random() * Double.MAX_VALUE)), diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/OptionResolver.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/OptionResolver.java index 8b6f8a88ace..09f7f20695c 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/OptionResolver.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/utils/OptionResolver.java @@ -230,7 +230,7 @@ public class OptionResolver { @Override public Long parseFromString(String arg) { - return new Long(arg); + return Long.valueOf(arg); } } @@ -242,7 +242,7 @@ public class OptionResolver { @Override public Integer parseFromString(String arg) { - return new Integer(arg); + return Integer.valueOf(arg); } } From 066208e3684da83ef69b1a46d4ff6ab557e23a84 Mon Sep 17 00:00:00 2001 From: Gustavo Romero Date: Mon, 23 May 2016 10:35:51 -0300 Subject: [PATCH 003/125] 8154156: PPC64: improve array copy stubs by using vector instructions Reviewed-by: goetz, mdoerr --- hotspot/src/cpu/ppc/vm/assembler_ppc.hpp | 21 ++++ .../src/cpu/ppc/vm/assembler_ppc.inline.hpp | 4 + hotspot/src/cpu/ppc/vm/register_ppc.cpp | 11 ++ hotspot/src/cpu/ppc/vm/register_ppc.hpp | 100 ++++++++++++++++++ hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp | 75 ++++++++++--- hotspot/src/cpu/ppc/vm/vm_version_ppc.cpp | 25 +++-- hotspot/src/cpu/ppc/vm/vm_version_ppc.hpp | 6 ++ 7 files changed, 214 insertions(+), 28 deletions(-) diff --git a/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp b/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp index c5e7087eadc..002f5133234 100644 --- a/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp @@ -503,6 +503,10 @@ class Assembler : public AbstractAssembler { LVSL_OPCODE = (31u << OPCODE_SHIFT | 6u << 1), LVSR_OPCODE = (31u << OPCODE_SHIFT | 38u << 1), + // Vector-Scalar (VSX) instruction support. + LXVD2X_OPCODE = (31u << OPCODE_SHIFT | 844u << 1), + STXVD2X_OPCODE = (31u << OPCODE_SHIFT | 972u << 1), + // Vector Permute and Formatting VPKPX_OPCODE = (4u << OPCODE_SHIFT | 782u ), VPKSHSS_OPCODE = (4u << OPCODE_SHIFT | 398u ), @@ -1085,6 +1089,19 @@ class Assembler : public AbstractAssembler { static int vrs( VectorRegister r) { return vrs(r->encoding());} static int vrt( VectorRegister r) { return vrt(r->encoding());} + // Support Vector-Scalar (VSX) instructions. + static int vsra( int x) { return opp_u_field(x, 15, 11); } + static int vsrb( int x) { return opp_u_field(x, 20, 16); } + static int vsrc( int x) { return opp_u_field(x, 25, 21); } + static int vsrs( int x) { return opp_u_field(x, 10, 6); } + static int vsrt( int x) { return opp_u_field(x, 10, 6); } + + static int vsra( VectorSRegister r) { return vsra(r->encoding());} + static int vsrb( VectorSRegister r) { return vsrb(r->encoding());} + static int vsrc( VectorSRegister r) { return vsrc(r->encoding());} + static int vsrs( VectorSRegister r) { return vsrs(r->encoding());} + static int vsrt( VectorSRegister r) { return vsrt(r->encoding());} + static int vsplt_uim( int x) { return opp_u_field(x, 15, 12); } // for vsplt* instructions static int vsplti_sim(int x) { return opp_u_field(x, 15, 11); } // for vsplti* instructions static int vsldoi_shb(int x) { return opp_u_field(x, 25, 22); } // for vsldoi instruction @@ -2065,6 +2082,10 @@ class Assembler : public AbstractAssembler { inline void mtvscr( VectorRegister b); inline void mfvscr( VectorRegister d); + // Vector-Scalar (VSX) instructions. + inline void lxvd2x( VectorSRegister d, Register a, Register b); + inline void stxvd2x( VectorSRegister d, Register a, Register b); + // AES (introduced with Power 8) inline void vcipher( VectorRegister d, VectorRegister a, VectorRegister b); inline void vcipherlast( VectorRegister d, VectorRegister a, VectorRegister b); diff --git a/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp b/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp index 4e7f7df8f24..220e3a727c8 100644 --- a/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp +++ b/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp @@ -721,6 +721,10 @@ inline void Assembler::stvxl( VectorRegister d, Register s1, Register s2) { emit inline void Assembler::lvsl( VectorRegister d, Register s1, Register s2) { emit_int32( LVSL_OPCODE | vrt(d) | ra0mem(s1) | rb(s2)); } inline void Assembler::lvsr( VectorRegister d, Register s1, Register s2) { emit_int32( LVSR_OPCODE | vrt(d) | ra0mem(s1) | rb(s2)); } +// Vector-Scalar (VSX) instructions. +inline void Assembler::lxvd2x (VectorSRegister d, Register s1, Register s2) { emit_int32( LXVD2X_OPCODE | vsrt(d) | ra(s1) | rb(s2)); } +inline void Assembler::stxvd2x(VectorSRegister d, Register s1, Register s2) { emit_int32( STXVD2X_OPCODE | vsrt(d) | ra(s1) | rb(s2)); } + inline void Assembler::vpkpx( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPKPX_OPCODE | vrt(d) | vra(a) | vrb(b)); } inline void Assembler::vpkshss( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPKSHSS_OPCODE | vrt(d) | vra(a) | vrb(b)); } inline void Assembler::vpkswss( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPKSWSS_OPCODE | vrt(d) | vra(a) | vrb(b)); } diff --git a/hotspot/src/cpu/ppc/vm/register_ppc.cpp b/hotspot/src/cpu/ppc/vm/register_ppc.cpp index e0b07c98168..8dcd325ad75 100644 --- a/hotspot/src/cpu/ppc/vm/register_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/register_ppc.cpp @@ -75,3 +75,14 @@ const char* VectorRegisterImpl::name() const { }; return is_valid() ? names[encoding()] : "vnoreg"; } + +const char* VectorSRegisterImpl::name() const { + const char* names[number_of_registers] = { + "VSR0", "VSR1", "VSR2", "VSR3", "VSR4", "VSR5", "VSR6", "VSR7", + "VSR8", "VSR9", "VSR10", "VSR11", "VSR12", "VSR13", "VSR14", "VSR15", + "VSR16", "VSR17", "VSR18", "VSR19", "VSR20", "VSR21", "VSR22", "VSR23", + "VSR24", "VSR25", "VSR26", "VSR27", "VSR28", "VSR29", "VSR30", "VSR31" + }; + return is_valid() ? names[encoding()] : "vsnoreg"; +} + diff --git a/hotspot/src/cpu/ppc/vm/register_ppc.hpp b/hotspot/src/cpu/ppc/vm/register_ppc.hpp index 8f6dda40eea..fffd7dc54a1 100644 --- a/hotspot/src/cpu/ppc/vm/register_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/register_ppc.hpp @@ -491,6 +491,106 @@ CONSTANT_REGISTER_DECLARATION(VectorRegister, VR31, (31)); #endif // DONT_USE_REGISTER_DEFINES +// Use VectorSRegister as a shortcut. +class VectorSRegisterImpl; +typedef VectorSRegisterImpl* VectorSRegister; + +inline VectorSRegister as_VectorSRegister(int encoding) { + return (VectorSRegister)(intptr_t)encoding; +} + +// The implementation of Vector-Scalar (VSX) registers on POWER architecture. +class VectorSRegisterImpl: public AbstractRegisterImpl { + public: + enum { + number_of_registers = 32 + }; + + // construction + inline friend VectorSRegister as_VectorSRegister(int encoding); + + // accessors + int encoding() const { assert(is_valid(), "invalid register"); return value(); } + + // testers + bool is_valid() const { return 0 <= value() && value() < number_of_registers; } + + const char* name() const; +}; + +// The Vector-Scalar (VSX) registers of the POWER architecture. + +CONSTANT_REGISTER_DECLARATION(VectorSRegister, vsnoreg, (-1)); + +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR0, ( 0)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR1, ( 1)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR2, ( 2)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR3, ( 3)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR4, ( 4)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR5, ( 5)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR6, ( 6)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR7, ( 7)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR8, ( 8)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR9, ( 9)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR10, (10)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR11, (11)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR12, (12)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR13, (13)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR14, (14)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR15, (15)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR16, (16)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR17, (17)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR18, (18)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR19, (19)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR20, (20)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR21, (21)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR22, (22)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR23, (23)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR24, (24)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR25, (25)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR26, (26)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR27, (27)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR28, (28)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR29, (29)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR30, (30)); +CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR31, (31)); + +#ifndef DONT_USE_REGISTER_DEFINES +#define vsnoregi ((VectorSRegister)(vsnoreg_VectorSRegisterEnumValue)) +#define VSR0 ((VectorSRegister)( VSR0_VectorSRegisterEnumValue)) +#define VSR1 ((VectorSRegister)( VSR1_VectorSRegisterEnumValue)) +#define VSR2 ((VectorSRegister)( VSR2_VectorSRegisterEnumValue)) +#define VSR3 ((VectorSRegister)( VSR3_VectorSRegisterEnumValue)) +#define VSR4 ((VectorSRegister)( VSR4_VectorSRegisterEnumValue)) +#define VSR5 ((VectorSRegister)( VSR5_VectorSRegisterEnumValue)) +#define VSR6 ((VectorSRegister)( VSR6_VectorSRegisterEnumValue)) +#define VSR7 ((VectorSRegister)( VSR7_VectorSRegisterEnumValue)) +#define VSR8 ((VectorSRegister)( VSR8_VectorSRegisterEnumValue)) +#define VSR9 ((VectorSRegister)( VSR9_VectorSRegisterEnumValue)) +#define VSR10 ((VectorSRegister)( VSR10_VectorSRegisterEnumValue)) +#define VSR11 ((VectorSRegister)( VSR11_VectorSRegisterEnumValue)) +#define VSR12 ((VectorSRegister)( VSR12_VectorSRegisterEnumValue)) +#define VSR13 ((VectorSRegister)( VSR13_VectorSRegisterEnumValue)) +#define VSR14 ((VectorSRegister)( VSR14_VectorSRegisterEnumValue)) +#define VSR15 ((VectorSRegister)( VSR15_VectorSRegisterEnumValue)) +#define VSR16 ((VectorSRegister)( VSR16_VectorSRegisterEnumValue)) +#define VSR17 ((VectorSRegister)( VSR17_VectorSRegisterEnumValue)) +#define VSR18 ((VectorSRegister)( VSR18_VectorSRegisterEnumValue)) +#define VSR19 ((VectorSRegister)( VSR19_VectorSRegisterEnumValue)) +#define VSR20 ((VectorSRegister)( VSR20_VectorSRegisterEnumValue)) +#define VSR21 ((VectorSRegister)( VSR21_VectorSRegisterEnumValue)) +#define VSR22 ((VectorSRegister)( VSR22_VectorSRegisterEnumValue)) +#define VSR23 ((VectorSRegister)( VSR23_VectorSRegisterEnumValue)) +#define VSR24 ((VectorSRegister)( VSR24_VectorSRegisterEnumValue)) +#define VSR25 ((VectorSRegister)( VSR25_VectorSRegisterEnumValue)) +#define VSR26 ((VectorSRegister)( VSR26_VectorSRegisterEnumValue)) +#define VSR27 ((VectorSRegister)( VSR27_VectorSRegisterEnumValue)) +#define VSR28 ((VectorSRegister)( VSR28_VectorSRegisterEnumValue)) +#define VSR29 ((VectorSRegister)( VSR29_VectorSRegisterEnumValue)) +#define VSR30 ((VectorSRegister)( VSR30_VectorSRegisterEnumValue)) +#define VSR31 ((VectorSRegister)( VSR31_VectorSRegisterEnumValue)) +#endif // DONT_USE_REGISTER_DEFINES + // Maximum number of incoming arguments that can be passed in i registers. const int PPC_ARGS_IN_REGS_NUM = 8; diff --git a/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp b/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp index 58222baa2fa..7ae89abd38f 100644 --- a/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp @@ -1341,10 +1341,13 @@ class StubGenerator: public StubCodeGenerator { Register tmp3 = R8_ARG6; Register tmp4 = R9_ARG7; + VectorSRegister tmp_vsr1 = VSR1; + VectorSRegister tmp_vsr2 = VSR2; + address start = __ function_entry(); assert_positive_int(R5_ARG3); - Label l_1, l_2, l_3, l_4, l_5, l_6, l_7, l_8; + Label l_1, l_2, l_3, l_4, l_5, l_6, l_7, l_8, l_9; // don't try anything fancy if arrays don't have many elements __ li(tmp3, 0); @@ -1403,22 +1406,60 @@ class StubGenerator: public StubCodeGenerator { __ andi_(R5_ARG3, R5_ARG3, 15); __ mtctr(tmp1); - __ bind(l_8); - // Use unrolled version for mass copying (copy 16 elements a time). - // Load feeding store gets zero latency on Power6, however not on Power5. - // Therefore, the following sequence is made for the good of both. - __ ld(tmp1, 0, R3_ARG1); - __ ld(tmp2, 8, R3_ARG1); - __ ld(tmp3, 16, R3_ARG1); - __ ld(tmp4, 24, R3_ARG1); - __ std(tmp1, 0, R4_ARG2); - __ std(tmp2, 8, R4_ARG2); - __ std(tmp3, 16, R4_ARG2); - __ std(tmp4, 24, R4_ARG2); - __ addi(R3_ARG1, R3_ARG1, 32); - __ addi(R4_ARG2, R4_ARG2, 32); - __ bdnz(l_8); - } + if (!VM_Version::has_vsx()) { + + __ bind(l_8); + // Use unrolled version for mass copying (copy 16 elements a time). + // Load feeding store gets zero latency on Power6, however not on Power5. + // Therefore, the following sequence is made for the good of both. + __ ld(tmp1, 0, R3_ARG1); + __ ld(tmp2, 8, R3_ARG1); + __ ld(tmp3, 16, R3_ARG1); + __ ld(tmp4, 24, R3_ARG1); + __ std(tmp1, 0, R4_ARG2); + __ std(tmp2, 8, R4_ARG2); + __ std(tmp3, 16, R4_ARG2); + __ std(tmp4, 24, R4_ARG2); + __ addi(R3_ARG1, R3_ARG1, 32); + __ addi(R4_ARG2, R4_ARG2, 32); + __ bdnz(l_8); + + } else { // Processor supports VSX, so use it to mass copy. + + // Prefetch src data into L2 cache. + __ dcbt(R3_ARG1, 0); + + // If supported set DSCR pre-fetch to deepest. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val | 7); + __ mtdscr(tmp2); + } + __ li(tmp1, 16); + + // Backbranch target aligned to 32-byte. It's not aligned 16-byte + // as loop contains < 8 instructions that fit inside a single + // i-cache sector. + __ align(32); + + __ bind(l_9); + // Use loop with VSX load/store instructions to + // copy 16 elements a time. + __ lxvd2x(tmp_vsr1, 0, R3_ARG1); // Load from src. + __ stxvd2x(tmp_vsr1, 0, R4_ARG2); // Store to dst. + __ lxvd2x(tmp_vsr2, R3_ARG1, tmp1); // Load from src + 16. + __ stxvd2x(tmp_vsr2, R4_ARG2, tmp1); // Store to dst + 16. + __ addi(R3_ARG1, R3_ARG1, 32); // Update src+=32. + __ addi(R4_ARG2, R4_ARG2, 32); // Update dsc+=32. + __ bdnz(l_9); // Dec CTR and loop if not zero. + + // Restore DSCR pre-fetch value. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val); + __ mtdscr(tmp2); + } + + } + } // FasterArrayCopy __ bind(l_6); // copy 2 elements at a time diff --git a/hotspot/src/cpu/ppc/vm/vm_version_ppc.cpp b/hotspot/src/cpu/ppc/vm/vm_version_ppc.cpp index 88c03a3dc43..3b0800d6e5f 100644 --- a/hotspot/src/cpu/ppc/vm/vm_version_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/vm_version_ppc.cpp @@ -38,7 +38,7 @@ # include bool VM_Version::_is_determine_features_test_running = false; - +uint64_t VM_Version::_dscr_val = 0; #define MSG(flag) \ if (flag && !FLAG_IS_DEFAULT(flag)) \ @@ -111,7 +111,7 @@ void VM_Version::initialize() { // Create and print feature-string. char buf[(num_features+1) * 16]; // Max 16 chars per feature. jio_snprintf(buf, sizeof(buf), - "ppc64%s%s%s%s%s%s%s%s%s%s%s%s%s", + "ppc64%s%s%s%s%s%s%s%s%s%s%s%s%s%s", (has_fsqrt() ? " fsqrt" : ""), (has_isel() ? " isel" : ""), (has_lxarxeh() ? " lxarxeh" : ""), @@ -125,7 +125,8 @@ void VM_Version::initialize() { (has_vcipher() ? " aes" : ""), (has_vpmsumb() ? " vpmsumb" : ""), (has_tcheck() ? " tcheck" : ""), - (has_mfdscr() ? " mfdscr" : "") + (has_mfdscr() ? " mfdscr" : ""), + (has_vsx() ? " vsx" : "") // Make sure number of %s matches num_features! ); _features_string = os::strdup(buf); @@ -643,6 +644,7 @@ void VM_Version::determine_features() { a->vpmsumb(VR0, VR1, VR2); // code[11] -> vpmsumb a->tcheck(0); // code[12] -> tcheck a->mfdscr(R0); // code[13] -> mfdscr + a->lxvd2x(VSR0, 0, R3_ARG1); // code[14] -> vsx a->blr(); // Emit function to set one cache line to zero. Emit function descriptor and get pointer to it. @@ -691,6 +693,7 @@ void VM_Version::determine_features() { if (code[feature_cntr++]) features |= vpmsumb_m; if (code[feature_cntr++]) features |= tcheck_m; if (code[feature_cntr++]) features |= mfdscr_m; + if (code[feature_cntr++]) features |= vsx_m; // Print the detection code. if (PrintAssembly) { @@ -733,31 +736,31 @@ void VM_Version::config_dscr() { } // Apply the configuration if needed. - uint64_t dscr_val = (*get_dscr)(); + _dscr_val = (*get_dscr)(); if (Verbose) { - tty->print_cr("dscr value was 0x%lx" , dscr_val); + tty->print_cr("dscr value was 0x%lx" , _dscr_val); } bool change_requested = false; if (DSCR_PPC64 != (uintx)-1) { - dscr_val = DSCR_PPC64; + _dscr_val = DSCR_PPC64; change_requested = true; } if (DSCR_DPFD_PPC64 <= 7) { uint64_t mask = 0x7; - if ((dscr_val & mask) != DSCR_DPFD_PPC64) { - dscr_val = (dscr_val & ~mask) | (DSCR_DPFD_PPC64); + if ((_dscr_val & mask) != DSCR_DPFD_PPC64) { + _dscr_val = (_dscr_val & ~mask) | (DSCR_DPFD_PPC64); change_requested = true; } } if (DSCR_URG_PPC64 <= 7) { uint64_t mask = 0x7 << 6; - if ((dscr_val & mask) != DSCR_DPFD_PPC64 << 6) { - dscr_val = (dscr_val & ~mask) | (DSCR_URG_PPC64 << 6); + if ((_dscr_val & mask) != DSCR_DPFD_PPC64 << 6) { + _dscr_val = (_dscr_val & ~mask) | (DSCR_URG_PPC64 << 6); change_requested = true; } } if (change_requested) { - (*set_dscr)(dscr_val); + (*set_dscr)(_dscr_val); if (Verbose) { tty->print_cr("dscr was set to 0x%lx" , (*get_dscr)()); } diff --git a/hotspot/src/cpu/ppc/vm/vm_version_ppc.hpp b/hotspot/src/cpu/ppc/vm/vm_version_ppc.hpp index fccb4e21874..2d1f8db990e 100644 --- a/hotspot/src/cpu/ppc/vm/vm_version_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/vm_version_ppc.hpp @@ -46,6 +46,7 @@ protected: vpmsumb, tcheck, mfdscr, + vsx, num_features // last entry to count features }; enum Feature_Flag_Set { @@ -64,6 +65,7 @@ protected: vpmsumb_m = (1 << vpmsumb), tcheck_m = (1 << tcheck ), mfdscr_m = (1 << mfdscr ), + vsx_m = (1 << vsx ), all_features_m = (unsigned long)-1 }; @@ -97,10 +99,14 @@ public: static bool has_vpmsumb() { return (_features & vpmsumb_m) != 0; } static bool has_tcheck() { return (_features & tcheck_m) != 0; } static bool has_mfdscr() { return (_features & mfdscr_m) != 0; } + static bool has_vsx() { return (_features & vsx_m) != 0; } // Assembler testing static void allow_all(); static void revert(); + + // POWER 8: DSCR current value. + static uint64_t _dscr_val; }; #endif // CPU_PPC_VM_VM_VERSION_PPC_HPP From c3d0e73480946e824636879da398e24862ece5f8 Mon Sep 17 00:00:00 2001 From: Jon Masamitsu Date: Wed, 25 May 2016 09:28:20 -0700 Subject: [PATCH 004/125] 8157620: Guarantee in run_task(task, num_workers) fails Reviewed-by: tschatzl, drwhite --- hotspot/src/share/vm/gc/shared/workgroup.cpp | 13 +++++++++---- hotspot/src/share/vm/gc/shared/workgroup.hpp | 6 +++++- hotspot/test/gc/stress/TestGCOld.java | 1 + 3 files changed, 15 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/workgroup.cpp b/hotspot/src/share/vm/gc/shared/workgroup.cpp index 0dfffcd82e8..f53285d9b26 100644 --- a/hotspot/src/share/vm/gc/shared/workgroup.cpp +++ b/hotspot/src/share/vm/gc/shared/workgroup.cpp @@ -60,6 +60,10 @@ AbstractGangWorker* AbstractWorkGang::install_worker(uint worker_id) { } void AbstractWorkGang::add_workers(bool initializing) { + add_workers(_active_workers, initializing); +} + +void AbstractWorkGang::add_workers(uint active_workers, bool initializing) { os::ThreadType worker_type; if (are_ConcurrentGC_threads()) { @@ -69,7 +73,7 @@ void AbstractWorkGang::add_workers(bool initializing) { } _created_workers = WorkerManager::add_workers(this, - _active_workers, + active_workers, _total_workers, _created_workers, worker_type, @@ -268,10 +272,11 @@ void WorkGang::run_task(AbstractGangTask* task) { } void WorkGang::run_task(AbstractGangTask* task, uint num_workers) { - guarantee(num_workers <= active_workers(), - "Trying to execute task %s with %u workers which is more than the amount of active workers %u.", - task->name(), num_workers, active_workers()); + guarantee(num_workers <= total_workers(), + "Trying to execute task %s with %u workers which is more than the amount of total workers %u.", + task->name(), num_workers, total_workers()); guarantee(num_workers > 0, "Trying to execute task %s with zero workers", task->name()); + add_workers(num_workers, false); _dispatcher->coordinator_execute_on_workers(task, num_workers); } diff --git a/hotspot/src/share/vm/gc/shared/workgroup.hpp b/hotspot/src/share/vm/gc/shared/workgroup.hpp index 388909168be..150365f4e04 100644 --- a/hotspot/src/share/vm/gc/shared/workgroup.hpp +++ b/hotspot/src/share/vm/gc/shared/workgroup.hpp @@ -170,6 +170,9 @@ class AbstractWorkGang : public CHeapObj { // Add GC workers as needed. void add_workers(bool initializing); + // Add GC workers as needed to reach the specified number of workers. + void add_workers(uint active_workers, bool initializing); + // Return the Ith worker. AbstractGangWorker* worker(uint i) const; @@ -214,7 +217,8 @@ public: virtual void run_task(AbstractGangTask* task); // Run a task with the given number of workers, returns // when the task is done. The number of workers must be at most the number of - // active workers. + // active workers. Additional workers may be created if an insufficient + // number currently exists. void run_task(AbstractGangTask* task, uint num_workers); protected: diff --git a/hotspot/test/gc/stress/TestGCOld.java b/hotspot/test/gc/stress/TestGCOld.java index 336cb09cca5..23fb60a3113 100644 --- a/hotspot/test/gc/stress/TestGCOld.java +++ b/hotspot/test/gc/stress/TestGCOld.java @@ -32,6 +32,7 @@ * @run main/othervm -Xmx384M -XX:+UseParallelGC -XX:-UseParallelOldGC TestGCOld 50 1 20 10 10000 * @run main/othervm -Xmx384M -XX:+UseConcMarkSweepGC TestGCOld 50 1 20 10 10000 * @run main/othervm -Xmx384M -XX:+UseG1GC TestGCOld 50 1 20 10 10000 + * @run main/othervm -Xms64m -Xmx128m -XX:+UseG1GC -XX:+UseDynamicNumberOfGCThreads -Xlog:gc,gc+task=trace TestGCOld 50 5 20 1 5000 */ import java.text.*; From 60fabf15a76891a4ecc892836a89a4f91566ce4f Mon Sep 17 00:00:00 2001 From: Fei Yang Date: Fri, 27 May 2016 01:02:16 +0800 Subject: [PATCH 005/125] 8156731: aarch64: java/util/Arrays/Correct.java fails due to _generic_arraycopy stub routine Fix address calculation considering compressed oops _generic_arraycopy stub routine Reviewed-by: aph --- hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp index 2355579ceab..075bf794650 100644 --- a/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp @@ -1299,7 +1299,7 @@ class StubGenerator: public StubCodeGenerator { if (VerifyOops) verify_oop_array(size, d, count, r16); __ sub(count, count, 1); // make an inclusive end pointer - __ lea(count, Address(d, count, Address::uxtw(exact_log2(size)))); + __ lea(count, Address(d, count, Address::lsl(exact_log2(size)))); gen_write_ref_array_post_barrier(d, count, rscratch1); } __ leave(); @@ -2002,9 +2002,9 @@ class StubGenerator: public StubCodeGenerator { arraycopy_range_checks(src, src_pos, dst, dst_pos, scratch_length, rscratch2, L_failed); - __ lea(from, Address(src, src_pos, Address::lsl(3))); + __ lea(from, Address(src, src_pos, Address::lsl(LogBytesPerHeapOop))); __ add(from, from, arrayOopDesc::base_offset_in_bytes(T_OBJECT)); - __ lea(to, Address(dst, dst_pos, Address::lsl(3))); + __ lea(to, Address(dst, dst_pos, Address::lsl(LogBytesPerHeapOop))); __ add(to, to, arrayOopDesc::base_offset_in_bytes(T_OBJECT)); __ movw(count, scratch_length); // length __ BIND(L_plain_copy); @@ -2027,9 +2027,9 @@ class StubGenerator: public StubCodeGenerator { __ load_klass(rscratch2_dst_klass, dst); // reload // Marshal the base address arguments now, freeing registers. - __ lea(from, Address(src, src_pos, Address::lsl(3))); + __ lea(from, Address(src, src_pos, Address::lsl(LogBytesPerHeapOop))); __ add(from, from, arrayOopDesc::base_offset_in_bytes(T_OBJECT)); - __ lea(to, Address(dst, dst_pos, Address::lsl(3))); + __ lea(to, Address(dst, dst_pos, Address::lsl(LogBytesPerHeapOop))); __ add(to, to, arrayOopDesc::base_offset_in_bytes(T_OBJECT)); __ movw(count, length); // length (reloaded) Register sco_temp = c_rarg3; // this register is free now From cf20f6fff82b0e01960314ced836b7d6b2116ea1 Mon Sep 17 00:00:00 2001 From: Teng Lu Date: Fri, 27 May 2016 20:38:38 +0800 Subject: [PATCH 006/125] 8157906: aarch64: some more integer rotate instructions are never emitted Fix wrong definition of source operand of left rotate instructions Reviewed-by: aph --- hotspot/src/cpu/aarch64/vm/aarch64.ad | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/hotspot/src/cpu/aarch64/vm/aarch64.ad b/hotspot/src/cpu/aarch64/vm/aarch64.ad index 6db1772b432..1aeae0bf38f 100644 --- a/hotspot/src/cpu/aarch64/vm/aarch64.ad +++ b/hotspot/src/cpu/aarch64/vm/aarch64.ad @@ -12179,21 +12179,21 @@ instruct rolL_rReg_Var_C0(iRegLNoSp dst, iRegL src, iRegI shift, immI0 c0, rFlag %} %} -instruct rolI_rReg_Var_C_32(iRegLNoSp dst, iRegL src, iRegI shift, immI_32 c_32, rFlagsReg cr) +instruct rolI_rReg_Var_C_32(iRegINoSp dst, iRegI src, iRegI shift, immI_32 c_32, rFlagsReg cr) %{ match(Set dst (OrI (LShiftI src shift) (URShiftI src (SubI c_32 shift)))); expand %{ - rolL_rReg(dst, src, shift, cr); + rolI_rReg(dst, src, shift, cr); %} %} -instruct rolI_rReg_Var_C0(iRegLNoSp dst, iRegL src, iRegI shift, immI0 c0, rFlagsReg cr) +instruct rolI_rReg_Var_C0(iRegINoSp dst, iRegI src, iRegI shift, immI0 c0, rFlagsReg cr) %{ match(Set dst (OrI (LShiftI src shift) (URShiftI src (SubI c0 shift)))); expand %{ - rolL_rReg(dst, src, shift, cr); + rolI_rReg(dst, src, shift, cr); %} %} From a0b8f9dc1a49167fcaadc0f0c2a477ba3ba4b969 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Mon, 30 May 2016 23:32:59 +0300 Subject: [PATCH 007/125] 8154123: remove commented action from jdk/vm/ci/runtime/test/ConstantTest.java Reviewed-by: shade, kvn --- .../src/jdk/vm/ci/runtime/test/ConstantTest.java | 1 - 1 file changed, 1 deletion(-) diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java index c14a69bf724..63230f38955 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java @@ -31,7 +31,6 @@ * @build jdk.vm.ci.runtime.test.ConstantTest * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.runtime.test.ConstantTest */ -// * @compile ConstantTest.java FieldUniverse.java TypeUniverse.java TestMetaAccessProvider.java package jdk.vm.ci.runtime.test; import org.junit.Assert; From 395f9470dfa2be06a96bfd5d9cd20e14b9f5fde5 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Mon, 30 May 2016 23:33:00 +0300 Subject: [PATCH 008/125] 8152376: [TESTBUG] compiler/floatingpoint/Test15FloatJNIArgs should use run main/othervm/native Reviewed-by: kvn --- hotspot/test/compiler/floatingpoint/Test15FloatJNIArgs.java | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/hotspot/test/compiler/floatingpoint/Test15FloatJNIArgs.java b/hotspot/test/compiler/floatingpoint/Test15FloatJNIArgs.java index 1425d3da016..9cb924318f5 100644 --- a/hotspot/test/compiler/floatingpoint/Test15FloatJNIArgs.java +++ b/hotspot/test/compiler/floatingpoint/Test15FloatJNIArgs.java @@ -25,9 +25,9 @@ * @bug 8139258 * @summary Regression test for 8139258 which failed to properly pass float args * to a jni function on ppc64le. - * @run main/othervm -Xint Test15FloatJNIArgs - * @run main/othervm -XX:+TieredCompilation -Xcomp Test15FloatJNIArgs - * @run main/othervm -XX:-TieredCompilation -Xcomp Test15FloatJNIArgs + * @run main/othervm/native -Xint Test15FloatJNIArgs + * @run main/othervm/native -XX:+TieredCompilation -Xcomp Test15FloatJNIArgs + * @run main/othervm/native -XX:-TieredCompilation -Xcomp Test15FloatJNIArgs */ public class Test15FloatJNIArgs { From 11504c438f03ebde13264a1499f643e5319b5df6 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 31 May 2016 15:12:09 +0300 Subject: [PATCH 009/125] 8073159: improve Test6857159.java Reviewed-by: kvn --- .../test/compiler/c2/6857159/Test6857159.java | 8 +-- .../test/compiler/c2/6857159/Test6857159.sh | 54 ------------------- 2 files changed, 4 insertions(+), 58 deletions(-) delete mode 100644 hotspot/test/compiler/c2/6857159/Test6857159.sh diff --git a/hotspot/test/compiler/c2/6857159/Test6857159.java b/hotspot/test/compiler/c2/6857159/Test6857159.java index 1d4b7520865..f412adf5876 100644 --- a/hotspot/test/compiler/c2/6857159/Test6857159.java +++ b/hotspot/test/compiler/c2/6857159/Test6857159.java @@ -34,12 +34,12 @@ import jdk.test.lib.*; public class Test6857159 { - public static void main(String[] args) throws Exception { - ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xbatch", "-XX:+PrintCompilation", - "-XX:CompileOnly=Test$ct.run", "Test"); - OutputAnalyzer analyzer = new OutputAnalyzer(pb.start()); + public static void main(String[] args) throws Throwable { + OutputAnalyzer analyzer = ProcessTools.executeTestJvm("-Xbatch", + "-XX:+PrintCompilation", "-XX:CompileOnly=Test$ct.run", "Test"); analyzer.shouldNotContain("COMPILE SKIPPED"); analyzer.shouldContain("Test$ct0::run (16 bytes)"); + analyzer.shouldHaveExitValue(0); } } diff --git a/hotspot/test/compiler/c2/6857159/Test6857159.sh b/hotspot/test/compiler/c2/6857159/Test6857159.sh deleted file mode 100644 index 0762fe17ca8..00000000000 --- a/hotspot/test/compiler/c2/6857159/Test6857159.sh +++ /dev/null @@ -1,54 +0,0 @@ -#!/bin/sh -# -# Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# -## some tests require path to find test source dir -if [ "${TESTSRC}" = "" ] -then - TESTSRC=${PWD} - echo "TESTSRC not set. Using "${TESTSRC}" as default" -fi -echo "TESTSRC=${TESTSRC}" -## Adding common setup Variables for running shell tests. -. ${TESTSRC}/../../../test_env.sh - -set -x - -cp ${TESTSRC}/Test6857159.java . -cp ${TESTSRC}/Test6857159.sh . - -${COMPILEJAVA}/bin/javac ${TESTJAVACOPTS} -d . Test6857159.java - -${TESTJAVA}/bin/java ${TESTOPTS} -Xbatch -XX:+PrintCompilation -XX:CompileOnly=Test6857159\$ct.run Test6857159 > test.out 2>&1 - -grep "COMPILE SKIPPED" test.out - -result=$? -if [ $result -eq 1 ] -then - echo "Passed" - exit 0 -else - echo "Failed" - exit 1 -fi From 3f436dc952e3760648b5c61ec6f4b14119da7ddf Mon Sep 17 00:00:00 2001 From: Dmitrij Pochepko Date: Tue, 31 May 2016 15:48:47 +0300 Subject: [PATCH 010/125] 8158065: [Jittester]: tests generation has tests generators hardcoded, blocking alternative tests generation Reviewed-by: iignatyev --- hotspot/test/testlibrary/jittester/Makefile | 5 + .../jittester/conf/default.properties | 2 + .../src/jdk/test/lib/jittester/Automatic.java | 190 ++++-------------- .../test/lib/jittester/ByteCodeGenerator.java | 63 +++--- .../test/lib/jittester/JavaCodeGenerator.java | 69 ++++--- .../test/lib/jittester/ProductionParams.java | 8 +- .../lib/jittester/TestGeneratorsFactory.java | 49 +++++ .../test/lib/jittester/TestsGenerator.java | 184 +++++++++++++++++ .../lib/jittester/jtreg/JitTesterDriver.java | 13 +- 9 files changed, 365 insertions(+), 218 deletions(-) create mode 100644 hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestGeneratorsFactory.java create mode 100644 hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestsGenerator.java diff --git a/hotspot/test/testlibrary/jittester/Makefile b/hotspot/test/testlibrary/jittester/Makefile index 91c996e4b4c..49470f7df71 100644 --- a/hotspot/test/testlibrary/jittester/Makefile +++ b/hotspot/test/testlibrary/jittester/Makefile @@ -44,6 +44,10 @@ ifneq "x$(SEED)" "x" APPLICATION_ARGS += --seed $(SEED) endif +ifneq "x$(EXTRA_SRC_DIR)" "x" + EXTRA_SRC_FILES := $(shell find $(EXTRA_SRC_DIR) -name '*.java') +endif + JAVA = $(JDK_HOME)/bin/java JAVAC = $(JDK_HOME)/bin/javac JAR = $(JDK_HOME)/bin/jar @@ -99,6 +103,7 @@ COMPILE: INIT filelist compile_testlib filelist: $(SRC_FILES) @rm -f $@ @echo $(SRC_FILES) > $@ + @echo $(EXTRA_SRC_FILES) >> $@ INIT: $(DIST_DIR) $(shell if [ ! -d $(CLASSES_DIR) ]; then mkdir -p $(CLASSES_DIR); fi) diff --git a/hotspot/test/testlibrary/jittester/conf/default.properties b/hotspot/test/testlibrary/jittester/conf/default.properties index edc980fd36e..e5d8a0bc39f 100644 --- a/hotspot/test/testlibrary/jittester/conf/default.properties +++ b/hotspot/test/testlibrary/jittester/conf/default.properties @@ -9,3 +9,5 @@ exclude-methods-file=conf/exclude.methods.lst print-complexity=true print-hierarchy=true disable-static=true +generatorsFactories=jdk.test.lib.jittester.TestGeneratorsFactory +generators=JavaCode,ByteCode diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/Automatic.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/Automatic.java index 3842d01f607..ee81bcf4e60 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/Automatic.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/Automatic.java @@ -25,50 +25,19 @@ package jdk.test.lib.jittester; import jdk.test.lib.Pair; import jdk.test.lib.jittester.factories.IRNodeBuilder; -import jdk.test.lib.jittester.jtreg.Printer; import jdk.test.lib.jittester.types.TypeKlass; import jdk.test.lib.jittester.utils.FixedTrees; import jdk.test.lib.jittester.utils.OptionResolver; import jdk.test.lib.jittester.utils.OptionResolver.Option; import jdk.test.lib.jittester.utils.PseudoRandom; - -import java.io.File; -import java.io.FileWriter; -import java.io.IOException; -import java.nio.file.Files; -import java.nio.file.Path; -import java.nio.file.Paths; import java.time.LocalTime; +import java.util.ArrayList; +import java.util.List; import java.util.concurrent.TimeUnit; -import java.util.stream.Collectors; +import java.util.function.Function; public class Automatic { - private static final int MINUTES_TO_WAIT = Integer.getInteger("jdk.test.lib.jittester", 3); - - static String getJtregHeader(String mainClass, boolean addCompile) { - String synopsis = "seed = '" + ProductionParams.seed.value() + "'" - + ", specificSeed = '" + PseudoRandom.getCurrentSeed() + "'"; - StringBuilder header = new StringBuilder(); - header.append("/*\n * @test\n * @summary ") - .append(synopsis) - .append(" \n* @library / ../\n"); - if (addCompile) { - header.append("\n * @compile ") - .append(mainClass) - .append(".java\n"); - } - header.append(" * @run build jdk.test.lib.jittester.jtreg.JitTesterDriver " - + "jdk.test.lib.jittester.jtreg.Printer\n") - .append(" * @run driver jdk.test.lib.jittester.jtreg.JitTesterDriver ") - .append(mainClass) - .append("\n */\n\n"); - if (ProductionParams.printHierarchy.value()) { - header.append("/*\n") - .append(Automatic.printHierarchy()) - .append("*/\n"); - } - return header.toString(); - } + public static final int MINUTES_TO_WAIT = Integer.getInteger("jdk.test.lib.jittester", 3); private static Pair generateIRTree(String name) { SymbolTable.removeAll(); @@ -120,123 +89,48 @@ public class Automatic { } } + private static List getTestGenerators() { + List result = new ArrayList<>(); + Class factoryClass; + Function> factory; + String[] factoryClassNames = ProductionParams.generatorsFactories.value().split(","); + String[] generatorNames = ProductionParams.generators.value().split(","); + for (String factoryClassName : factoryClassNames) { + try { + factoryClass = Class.forName(factoryClassName); + factory = (Function>) factoryClass.newInstance(); + } catch (ReflectiveOperationException roe) { + throw new Error("Can't instantiate generators factory", roe); + } + result.addAll(factory.apply(generatorNames)); + } + return result; + } + public static void main(String[] args) { initializeTestGenerator(args); int counter = 0; - try { - Path testbaseDir = Paths.get(ProductionParams.testbaseDir.value()); - System.out.printf(" %13s | %8s | %8s | %8s |%n", "start time", "count", "generat", - "running"); - System.out.printf(" %13s | %8s | %8s | %8s |%n", "---", "---", "---","---"); - String path = getJavaPath(); - String javacPath = Paths.get(path, "javac").toString(); - String javaPath = Paths.get(path, "java").toString(); - - // compile Printer class first. A common one for all tests - ensureExisting(testbaseDir); - ProcessBuilder pbPrinter = new ProcessBuilder(javacPath, - Paths.get(testbaseDir.toString(), "jdk", "test", "lib", "jittester", - "jtreg", "Printer.java").toString()); - runProcess(pbPrinter, testbaseDir.resolve("Printer").toString()); - do { - double start = System.currentTimeMillis(); - System.out.print("[" + LocalTime.now() + "] |"); - String name = "Test_" + counter; - Pair irTree = generateIRTree(name); - System.out.printf(" %8d |", counter); - double generationTime = System.currentTimeMillis() - start; - System.out.printf(" %8.0f |", generationTime); - if (!ProductionParams.disableJavacodeGeneration.value()) { - JavaCodeGenerator generator = new JavaCodeGenerator(); - String javaFile = generator.apply(irTree.first, irTree.second); - ProcessBuilder pb = new ProcessBuilder(javacPath, "-cp", testbaseDir.toString() - + ":" + generator.getTestbase().toString(), javaFile); - runProcess(pb, generator.getTestbase().resolve(name).toString()); - start = System.currentTimeMillis(); - - // Run compiled class files - pb = new ProcessBuilder(javaPath, "-Xint", "-cp", testbaseDir.toString() - + ":" + generator.getTestbase().toString(), name); - String goldFile = name + ".gold"; - runProcess(pb, generator.getTestbase().resolve(goldFile).toString()); - } - - if (!ProductionParams.disableBytecodeGeneration.value()) { - ByteCodeGenerator generator = new ByteCodeGenerator(); - generator.apply(irTree.first, irTree.second); - generator.writeJtregBytecodeRunner(name); - // Run generated bytecode - ProcessBuilder pb = new ProcessBuilder(javaPath, "-Xint", "-Xverify", "-cp", - testbaseDir.toString() + ":" + generator.getTestbase().toString(), - name); - String goldFile = name + ".gold"; - start = System.currentTimeMillis(); - runProcess(pb, generator.getTestbase().resolve(goldFile).toString()); - } - - double runningTime = System.currentTimeMillis() - start; - System.out.printf(" %8.0f |%n", runningTime); - if (runningTime < TimeUnit.MINUTES.toMillis(MINUTES_TO_WAIT)) { - ++counter; - } - } while (counter < ProductionParams.numberOfTests.value()); - } catch (IOException | InterruptedException ex) { - ex.printStackTrace(); - } - } - - private static String getJavaPath() { - String[] env = { "JDK_HOME", "JAVA_HOME", "BOOTDIR" }; - for (String name : env) { - String path = System.getenv(name); - if (path != null) { - return path + "/bin/"; + System.out.printf(" %13s | %8s | %8s | %8s |%n", "start time", "count", "generat", + "running"); + System.out.printf(" %13s | %8s | %8s | %8s |%n", "---", "---", "---", "---"); + List generators = getTestGenerators(); + do { + double start = System.currentTimeMillis(); + System.out.print("[" + LocalTime.now() + "] |"); + String name = "Test_" + counter; + Pair irTree = generateIRTree(name); + System.out.printf(" %8d |", counter); + double generationTime = System.currentTimeMillis() - start; + System.out.printf(" %8.0f |", generationTime); + start = System.currentTimeMillis(); + for (TestsGenerator generator : generators) { + generator.accept(irTree.first, irTree.second); } - } - return ""; - } - - private static int runProcess(ProcessBuilder pb, String name) - throws IOException, InterruptedException { - pb.redirectError(new File(name + ".err")); - pb.redirectOutput(new File(name + ".out")); - Process process = pb.start(); - if (process.waitFor(MINUTES_TO_WAIT, TimeUnit.MINUTES)) { - try (FileWriter file = new FileWriter(name + ".exit")) { - file.write(Integer.toString(process.exitValue())); + double runningTime = System.currentTimeMillis() - start; + System.out.printf(" %8.0f |%n", runningTime); + if (runningTime < TimeUnit.MINUTES.toMillis(MINUTES_TO_WAIT)) { + ++counter; } - return process.exitValue(); - } else { - process.destroyForcibly(); - return -1; - } - } - - private static String printHierarchy() { - return TypeList.getAll().stream() - .filter(t -> t instanceof TypeKlass) - .map(t -> typeDescription((TypeKlass) t)) - .collect(Collectors.joining("\n","CLASS HIERARCHY:\n", "\n")); - } - - private static String typeDescription(TypeKlass type) { - StringBuilder result = new StringBuilder(); - String parents = type.getParentsNames().stream().collect(Collectors.joining(",")); - result.append(type.isAbstract() ? "abstract " : "") - .append(type.isFinal() ? "final " : "") - .append(type.isInterface() ? "interface " : "class ") - .append(type.getName()) - .append(parents.isEmpty() ? "" : ": " + parents); - return result.toString(); - } - - static void ensureExisting(Path path) { - if (Files.notExists(path)) { - try { - Files.createDirectories(path); - } catch (IOException ex) { - ex.printStackTrace(); - } - } + } while (counter < ProductionParams.numberOfTests.value()); } } diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java index c13b9fbdf9d..94957ba3202 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java @@ -23,54 +23,60 @@ package jdk.test.lib.jittester; -import jdk.test.lib.jittester.visitors.ByteCodeVisitor; - import java.io.FileOutputStream; -import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; import java.nio.file.Files; import java.nio.file.Path; -import java.nio.file.Paths; import java.nio.file.StandardOpenOption; -import java.util.function.BiFunction; +import java.util.function.Function; +import jdk.test.lib.jittester.visitors.ByteCodeVisitor; /** - * Generates class files from bytecode + * Generates class files from IRTree */ -class ByteCodeGenerator implements BiFunction { - private final Path testbase = Paths.get(ProductionParams.testbaseDir.value(), - "bytecode_tests"); +class ByteCodeGenerator extends TestsGenerator { + private static final String DEFAULT_SUFFIX = "bytecode_tests"; - public void writeJtregBytecodeRunner(String name) { - try (FileWriter file = new FileWriter(testbase.resolve(name + ".java").toFile())) { - file.write(Automatic.getJtregHeader(name, false)); - } catch (IOException e) { - e.printStackTrace(); - } + ByteCodeGenerator() { + super(DEFAULT_SUFFIX); } - public String apply(IRNode mainClass, IRNode privateClasses) { - Automatic.ensureExisting(testbase); + ByteCodeGenerator(String suffix, Function preRunActions, String jtDriverOptions) { + super(suffix, preRunActions, jtDriverOptions); + } + + @Override + public void accept(IRNode mainClass, IRNode privateClasses) { + generateClassFiles(mainClass, privateClasses); + generateSeparateJtregHeader(mainClass); + compilePrinter(); + generateGoldenOut(mainClass.getName()); + } + + private void generateSeparateJtregHeader(IRNode mainClass) { + String mainClassName = mainClass.getName(); + writeFile(generatorDir, mainClassName + ".java", getJtregHeader(mainClassName)); + } + + private void generateClassFiles(IRNode mainClass, IRNode privateClasses) { + String mainClassName = mainClass.getName(); + ensureExisting(generatorDir); try { ByteCodeVisitor vis = new ByteCodeVisitor(); if (privateClasses != null) { privateClasses.accept(vis); } mainClass.accept(vis); - - Path mainClassPath = testbase.resolve(mainClass.getName() + ".class"); - writeToClassFile(mainClassPath, vis.getByteCode(mainClass.getName())); + writeFile(mainClassName + ".class", vis.getByteCode(mainClassName)); if (privateClasses != null) { privateClasses.getChildren().forEach(c -> { String name = c.getName(); - Path classPath = testbase.resolve(name + ".class"); - writeToClassFile(classPath, vis.getByteCode(name)); + writeFile(name + ".class", vis.getByteCode(name)); }); } - return mainClassPath.toString(); } catch (Throwable t) { - Path errFile = testbase.resolve(mainClass.getName() + ".err"); + Path errFile = generatorDir.resolve(mainClassName + ".err"); try (PrintWriter pw = new PrintWriter(Files.newOutputStream(errFile, StandardOpenOption.CREATE_NEW))) { t.printStackTrace(pw); @@ -78,16 +84,11 @@ class ByteCodeGenerator implements BiFunction { t.printStackTrace(); throw new Error("can't write error to error file " + errFile, e); } - return null; } } - public Path getTestbase() { - return testbase; - } - - private void writeToClassFile(Path path, byte[] bytecode) { - try (FileOutputStream file = new FileOutputStream(path.toString())) { + private void writeFile(String fileName, byte[] bytecode) { + try (FileOutputStream file = new FileOutputStream(generatorDir.resolve(fileName).toFile())) { file.write(bytecode); } catch (IOException ex) { ex.printStackTrace(); diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/JavaCodeGenerator.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/JavaCodeGenerator.java index 9f9e2a3387f..5c28487ad15 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/JavaCodeGenerator.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/JavaCodeGenerator.java @@ -23,48 +23,59 @@ package jdk.test.lib.jittester; +import java.io.File; +import java.io.IOException; +import java.util.function.Function; import jdk.test.lib.jittester.visitors.JavaCodeVisitor; -import java.io.FileWriter; -import java.io.IOException; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.util.function.BiFunction; - /** - * Generates class files from java source code + * Generates java source code from IRTree */ -class JavaCodeGenerator implements BiFunction { - private final Path testbase = Paths.get(ProductionParams.testbaseDir.value(), "java_tests"); +public class JavaCodeGenerator extends TestsGenerator { + private static final String DEFAULT_SUFFIX = "java_tests"; - private String generateJavaCode(IRNode mainClass, IRNode privateClasses) { + JavaCodeGenerator() { + this(DEFAULT_SUFFIX, JavaCodeGenerator::generatePrerunAction, ""); + } + + JavaCodeGenerator(String prefix, Function preRunActions, String jtDriverOptions) { + super(prefix, preRunActions, jtDriverOptions); + } + + @Override + public void accept(IRNode mainClass, IRNode privateClasses) { + String mainClassName = mainClass.getName(); + generateSources(mainClass, privateClasses); + compilePrinter(); + compileJavaFile(mainClassName); + generateGoldenOut(mainClassName); + } + + private void generateSources(IRNode mainClass, IRNode privateClasses) { + String mainClassName = mainClass.getName(); StringBuilder code = new StringBuilder(); JavaCodeVisitor vis = new JavaCodeVisitor(); - - code.append(Automatic.getJtregHeader(mainClass.getName(), true)); + code.append(getJtregHeader(mainClassName)); if (privateClasses != null) { code.append(privateClasses.accept(vis)); } code.append(mainClass.accept(vis)); - - return code.toString(); + ensureExisting(generatorDir); + writeFile(generatorDir, mainClassName + ".java", code.toString()); } - public Path getTestbase() { - return testbase; - } - - @Override - public String apply(IRNode mainClass, IRNode privateClasses) { - String code = generateJavaCode(mainClass, privateClasses); - Automatic.ensureExisting(testbase); - Path fileName = testbase.resolve(mainClass.getName() + ".java"); - try (FileWriter file = new FileWriter(fileName.toFile())) { - file.write(code); - return fileName.toString(); - } catch (IOException ex) { - ex.printStackTrace(); + private void compileJavaFile(String mainClassName) { + String classPath = getRoot() + File.pathSeparator + generatorDir; + ProcessBuilder pb = new ProcessBuilder(JAVAC, "-cp", classPath, + generatorDir.resolve(mainClassName + ".java").toString()); + try { + runProcess(pb, generatorDir.resolve(mainClassName).toString()); + } catch (IOException | InterruptedException e) { + throw new Error("Can't compile sources ", e); } - return ""; + } + + private static String[] generatePrerunAction(String mainClassName) { + return new String[] {"@compile " + mainClassName + ".java"}; } } diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ProductionParams.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ProductionParams.java index f3e7a6329fb..7a8256f0b12 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ProductionParams.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ProductionParams.java @@ -68,8 +68,6 @@ public class ProductionParams { public static Option disableNestedBlocks = null; public static Option disableArrays = null; public static Option enableFinalizers = null; - public static Option disableBytecodeGeneration = null; - public static Option disableJavacodeGeneration = null; // workaraound: to reduce chance throwing ArrayIndexOutOfBoundsException public static Option chanceExpressionIndex = null; public static Option testbaseDir = null; @@ -78,6 +76,8 @@ public class ProductionParams { public static Option specificSeed = null; public static Option classesFile = null; public static Option excludeMethodsFile = null; + public static Option generators = null; + public static Option generatorsFactories = null; public static void register(OptionResolver optionResolver) { productionLimit = optionResolver.addIntegerOption('l', "production-limit", 100, "Limit on steps in the production of an expression"); @@ -120,8 +120,6 @@ public class ProductionParams { disableNestedBlocks = optionResolver.addBooleanOption("disable-nested-blocks", "Disable generation of nested blocks"); disableArrays = optionResolver.addBooleanOption("disable-arrays", "Disable generation of arrays"); enableFinalizers = optionResolver.addBooleanOption("enable-finalizers", "Enable finalizers (for stress testing)"); - disableBytecodeGeneration = optionResolver.addBooleanOption("disable-bytecode-generation", "Disable generation of bytecode output"); - disableJavacodeGeneration = optionResolver.addBooleanOption("disable-javacode-generation", "Disable generation of java source code output"); chanceExpressionIndex = optionResolver.addIntegerOption("chance-expression-index", 0, "A non negative decimal integer used to restrict chane of generating expression in array index while creating or accessing by index"); testbaseDir = optionResolver.addStringOption("testbase-dir", ".", "Testbase dir"); numberOfTests = optionResolver.addIntegerOption('n', "number-of-tests", 0, "Number of test classes to generate"); @@ -129,5 +127,7 @@ public class ProductionParams { specificSeed = optionResolver.addLongOption('z', "specificSeed", 0L, "A seed to be set for specific test generation(regular seed still needed for initialization)"); classesFile = optionResolver.addStringOption('f', "classes-file", "conf/classes.lst", "File to read classes from"); excludeMethodsFile = optionResolver.addStringOption('r', "exclude-methods-file", "conf/exclude.methods.lst", "File to read excluded methods from"); + generators = optionResolver.addStringOption("generators", "", "Comma-separated list of generator names"); + generatorsFactories = optionResolver.addStringOption("generatorsFactories", "", "Comma-separated list of generators factories class names"); } } diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestGeneratorsFactory.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestGeneratorsFactory.java new file mode 100644 index 00000000000..ac4418d7952 --- /dev/null +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestGeneratorsFactory.java @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package jdk.test.lib.jittester; + +import java.util.ArrayList; +import java.util.List; +import java.util.function.Function; + +public class TestGeneratorsFactory implements Function> { + + @Override + public List apply(String[] input) { + List result = new ArrayList<>(); + for (String generatorName : input) { + switch (generatorName) { + case "JavaCode": + result.add(new JavaCodeGenerator()); + break; + case "ByteCode": + result.add(new ByteCodeGenerator()); + break; + default: + throw new IllegalArgumentException("Unknown generator: " + generatorName); + } + } + return result; + } +} diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestsGenerator.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestsGenerator.java new file mode 100644 index 00000000000..3974f078d7b --- /dev/null +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/TestsGenerator.java @@ -0,0 +1,184 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package jdk.test.lib.jittester; + +import java.io.File; +import java.io.FileWriter; +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.util.concurrent.TimeUnit; +import java.util.function.BiConsumer; +import java.util.function.Function; +import java.util.stream.Collectors; +import jdk.test.lib.jittester.types.TypeKlass; +import jdk.test.lib.jittester.utils.PseudoRandom; + +public abstract class TestsGenerator implements BiConsumer { + protected static final String JAVA_BIN = getJavaPath(); + protected static final String JAVAC = Paths.get(JAVA_BIN, "javac").toString(); + protected static final String JAVA = Paths.get(JAVA_BIN, "java").toString(); + protected final Path generatorDir; + protected final Function preRunActions; + protected final String jtDriverOptions; + + protected TestsGenerator(String suffix) { + this(suffix, s -> new String[0], ""); + } + + protected TestsGenerator(String suffix, Function preRunActions, + String jtDriverOptions) { + generatorDir = getRoot().resolve(suffix); + this.preRunActions = preRunActions; + this.jtDriverOptions = jtDriverOptions; + } + + protected void generateGoldenOut(String mainClassName) { + String classPath = getRoot() + File.pathSeparator + generatorDir; + ProcessBuilder pb = new ProcessBuilder(JAVA, "-Xint", "-Xverify", "-cp", classPath, + mainClassName); + String goldFile = mainClassName + ".gold"; + try { + runProcess(pb, generatorDir.resolve(goldFile).toString()); + } catch (IOException | InterruptedException e) { + throw new Error("Can't run generated test ", e); + } + } + + protected static int runProcess(ProcessBuilder pb, String name) + throws IOException, InterruptedException { + pb.redirectError(new File(name + ".err")); + pb.redirectOutput(new File(name + ".out")); + Process process = pb.start(); + if (process.waitFor(Automatic.MINUTES_TO_WAIT, TimeUnit.MINUTES)) { + try (FileWriter file = new FileWriter(name + ".exit")) { + file.write(Integer.toString(process.exitValue())); + } + return process.exitValue(); + } else { + process.destroyForcibly(); + return -1; + } + } + + protected static void compilePrinter() { + Path root = getRoot(); + ProcessBuilder pbPrinter = new ProcessBuilder(JAVAC, + root.resolve("jdk") + .resolve("test") + .resolve("lib") + .resolve("jittester") + .resolve("jtreg") + .resolve("Printer.java") + .toString()); + try { + int exitCode = runProcess(pbPrinter, root.resolve("Printer").toString()); + if (exitCode != 0) { + throw new Error("Printer compilation returned exit code " + exitCode); + } + } catch (IOException | InterruptedException e) { + throw new Error("Can't compile printer", e); + } + } + + protected static void ensureExisting(Path path) { + if (Files.notExists(path)) { + try { + Files.createDirectories(path); + } catch (IOException ex) { + ex.printStackTrace(); + } + } + } + + protected String getJtregHeader(String mainClassName) { + String synopsis = "seed = '" + ProductionParams.seed.value() + "'" + + ", specificSeed = '" + PseudoRandom.getCurrentSeed() + "'"; + StringBuilder header = new StringBuilder(); + header.append("/*\n * @test\n * @summary ") + .append(synopsis) + .append(" \n * @library / ../\n"); + header.append(" * @run build jdk.test.lib.jittester.jtreg.JitTesterDriver " + + "jdk.test.lib.jittester.jtreg.Printer\n"); + for (String action : preRunActions.apply(mainClassName)) { + header.append(" * ") + .append(action) + .append("\n"); + } + header.append(" * @run driver jdk.test.lib.jittester.jtreg.JitTesterDriver ") + .append(jtDriverOptions) + .append(" ") + .append(mainClassName) + .append("\n */\n\n"); + if (ProductionParams.printHierarchy.value()) { + header.append("/*\n") + .append(printHierarchy()) + .append("*/\n"); + } + return header.toString(); + } + + protected static Path getRoot() { + return Paths.get(ProductionParams.testbaseDir.value()); + } + + protected static void writeFile(Path targetDir, String fileName, String content) { + try (FileWriter file = new FileWriter(targetDir.resolve(fileName).toFile())) { + file.write(content); + } catch (IOException e) { + e.printStackTrace(); + } + } + + private static String printHierarchy() { + return TypeList.getAll() + .stream() + .filter(t -> t instanceof TypeKlass) + .map(t -> typeDescription((TypeKlass) t)) + .collect(Collectors.joining("\n","CLASS HIERARCHY:\n", "\n")); + } + + private static String typeDescription(TypeKlass type) { + StringBuilder result = new StringBuilder(); + String parents = type.getParentsNames().stream().collect(Collectors.joining(",")); + result.append(type.isAbstract() ? "abstract " : "") + .append(type.isFinal() ? "final " : "") + .append(type.isInterface() ? "interface " : "class ") + .append(type.getName()) + .append(parents.isEmpty() ? "" : ": " + parents); + return result.toString(); + } + + private static String getJavaPath() { + String[] env = { "JDK_HOME", "JAVA_HOME", "BOOTDIR" }; + for (String name : env) { + String path = System.getenv(name); + if (path != null) { + return path + "/bin/"; + } + } + return ""; + } +} diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java index d6b7db9ee41..72613da0049 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/jtreg/JitTesterDriver.java @@ -40,30 +40,31 @@ import java.util.stream.Stream; public class JitTesterDriver { public static void main(String[] args) { - if (args.length != 1) { + if (args.length < 1) { throw new IllegalArgumentException( "[TESTBUG]: wrong number of argument : " + args.length - + ". Expected 1 argument -- jit-tester test name."); + + ". Expected at least 1 argument -- jit-tester test name."); } OutputAnalyzer oa; try { - ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(true, args[0]); + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(true, args); oa = new OutputAnalyzer(pb.start()); } catch (Exception e) { throw new Error("Unexpected exception on test jvm start :" + e, e); } + String name = args[args.length - 1]; Pattern splitOut = Pattern.compile("\\n"); // tests use \n only in stdout Pattern splitErr = Pattern.compile("\\r?\\n"); // can handle both \r\n and \n Path testDir = Paths.get(Utils.TEST_SRC); - String goldOut = formatOutput(streamGoldFile(testDir, args[0], "out")); + String goldOut = formatOutput(streamGoldFile(testDir, name, "out")); String anlzOut = formatOutput(Arrays.stream(splitOut.split(oa.getStdout()))); Asserts.assertEQ(anlzOut, goldOut, "Actual stdout isn't equal to golden one"); - String goldErr = formatOutput(streamGoldFile(testDir, args[0], "err")); + String goldErr = formatOutput(streamGoldFile(testDir, name, "err")); String anlzErr = formatOutput(Arrays.stream(splitErr.split(oa.getStderr()))); Asserts.assertEQ(anlzErr, goldErr, "Actual stderr isn't equal to golden one"); - int exitValue = Integer.parseInt(streamGoldFile(testDir, args[0], "exit").findFirst().get()); + int exitValue = Integer.parseInt(streamGoldFile(testDir, name, "exit").findFirst().get()); oa.shouldHaveExitValue(exitValue); } From 7073d102f08b6eeb62463e3b3e1c076bbea50b48 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 31 May 2016 16:29:45 +0300 Subject: [PATCH 011/125] 8158182: remove shell script from compiler/c2/6894807/IsInstanceTest.java Reviewed-by: kvn --- .../compiler/c2/6894807/IsInstanceTest.java | 11 +---- .../test/compiler/c2/6894807/Test6894807.sh | 48 ------------------- 2 files changed, 2 insertions(+), 57 deletions(-) delete mode 100644 hotspot/test/compiler/c2/6894807/Test6894807.sh diff --git a/hotspot/test/compiler/c2/6894807/IsInstanceTest.java b/hotspot/test/compiler/c2/6894807/IsInstanceTest.java index d838c6ec662..6350109404c 100644 --- a/hotspot/test/compiler/c2/6894807/IsInstanceTest.java +++ b/hotspot/test/compiler/c2/6894807/IsInstanceTest.java @@ -25,8 +25,7 @@ * @test * @bug 6894807 * @summary No ClassCastException for HashAttributeSet constructors if run with -Xcomp - * @compile IsInstanceTest.java - * @run shell Test6894807.sh + * @run main IsInstanceTest */ public class IsInstanceTest { @@ -35,13 +34,7 @@ public class IsInstanceTest { BaseInterface baseInterfaceImpl = new BaseInterfaceImpl(); for (int i = 0; i < 100000; i++) { if (isInstanceOf(baseInterfaceImpl, ExtendedInterface.class)) { - System.out.println("Failed at index:" + i); - System.out.println("Arch: "+System.getProperty("os.arch", "")+ - " OS: "+System.getProperty("os.name", "")+ - " OSV: "+System.getProperty("os.version", "")+ - " Cores: "+Runtime.getRuntime().availableProcessors()+ - " JVM: "+System.getProperty("java.version", "")+" "+System.getProperty("sun.arch.data.model", "")); - break; + throw new AssertionError("Failed at index:" + i); } } System.out.println("Done!"); diff --git a/hotspot/test/compiler/c2/6894807/Test6894807.sh b/hotspot/test/compiler/c2/6894807/Test6894807.sh deleted file mode 100644 index bf10ba263bf..00000000000 --- a/hotspot/test/compiler/c2/6894807/Test6894807.sh +++ /dev/null @@ -1,48 +0,0 @@ -#!/bin/sh -# -# Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -if [ "${TESTSRC}" = "" ] -then - TESTSRC=${PWD} - echo "TESTSRC not set. Using "${TESTSRC}" as default" -fi -echo "TESTSRC=${TESTSRC}" - -## Adding common setup Variables for running shell tests. -. ${TESTSRC}/../../../test_env.sh - -${TESTJAVA}${FS}bin${FS}java ${TESTOPTS} IsInstanceTest > test.out 2>&1 - -cat test.out - -grep "Failed at index" test.out - -if [ $? = 0 ] -then - echo "Test Failed" - exit 1 -else - echo "Test Passed" - exit 0 -fi From 708d50417ce73193bc4dd564bb24fd70ed026999 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 31 May 2016 16:29:45 +0300 Subject: [PATCH 012/125] 8158185: jdk/test/lib/FileInstaller throws NPE if dst is in current directory Reviewed-by: kvn --- hotspot/test/testlibrary/jdk/test/lib/FileInstaller.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/hotspot/test/testlibrary/jdk/test/lib/FileInstaller.java b/hotspot/test/testlibrary/jdk/test/lib/FileInstaller.java index c5f92527258..7a8e3b8575c 100644 --- a/hotspot/test/testlibrary/jdk/test/lib/FileInstaller.java +++ b/hotspot/test/testlibrary/jdk/test/lib/FileInstaller.java @@ -45,8 +45,8 @@ public class FileInstaller { if (args.length != 2) { throw new IllegalArgumentException("Unexpected number of arguments for file copy"); } - Path src = Paths.get(Utils.TEST_SRC, args[0]); - Path dst = Paths.get(args[1]); + Path src = Paths.get(Utils.TEST_SRC, args[0]).toAbsolutePath(); + Path dst = Paths.get(args[1]).toAbsolutePath(); if (src.toFile().exists()) { if (src.toFile().isDirectory()) { Files.walkFileTree(src, new CopyFileVisitor(src, dst)); From fe34e32f2b92fe53bd5da55652e692a3ebe8f771 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 31 May 2016 16:29:45 +0300 Subject: [PATCH 013/125] 8158184: remove shell from compiler/c2/7070134/Stemmer.java Reviewed-by: kvn --- hotspot/test/compiler/c2/7070134/Stemmer.java | 8 ++-- .../test/compiler/c2/7070134/Test7070134.sh | 45 ------------------- 2 files changed, 5 insertions(+), 48 deletions(-) delete mode 100644 hotspot/test/compiler/c2/7070134/Test7070134.sh diff --git a/hotspot/test/compiler/c2/7070134/Stemmer.java b/hotspot/test/compiler/c2/7070134/Stemmer.java index 49484f94f2b..b8dbc053c61 100644 --- a/hotspot/test/compiler/c2/7070134/Stemmer.java +++ b/hotspot/test/compiler/c2/7070134/Stemmer.java @@ -2,8 +2,10 @@ * @test * @bug 7070134 * @summary Hotspot crashes with sigsegv from PorterStemmer - * - * @run shell Test7070134.sh + * @modules java.base/jdk.internal.misc + * @library /testlibrary + * @run driver jdk.test.lib.FileInstaller words words + * @run main/othervm -Xbatch Stemmer words */ /* @@ -61,7 +63,7 @@ import java.io.*; * by calling one of the various stem(something) methods. */ -class Stemmer +public class Stemmer { private char[] b; private int i, /* offset into b */ i_end, /* offset to end of stemmed word */ diff --git a/hotspot/test/compiler/c2/7070134/Test7070134.sh b/hotspot/test/compiler/c2/7070134/Test7070134.sh deleted file mode 100644 index b79b5b16e5a..00000000000 --- a/hotspot/test/compiler/c2/7070134/Test7070134.sh +++ /dev/null @@ -1,45 +0,0 @@ -#!/bin/sh -# -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code 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 -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# -# -## some tests require path to find test source dir -if [ "${TESTSRC}" = "" ] -then - TESTSRC=${PWD} - echo "TESTSRC not set. Using "${TESTSRC}" as default" -fi -echo "TESTSRC=${TESTSRC}" -## Adding common setup Variables for running shell tests. -. ${TESTSRC}/../../../test_env.sh - -set -x - -cp ${TESTSRC}/Stemmer.java . -cp ${TESTSRC}/words . - -${COMPILEJAVA}/bin/javac ${TESTJAVACOPTS} -d . Stemmer.java - -${TESTJAVA}/bin/java ${TESTOPTS} -Xbatch Stemmer words > test.out 2>&1 - -exit $? - From 56be0b11f1a0ebf932584a2696b1996eeec345eb Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Tue, 31 May 2016 16:30:18 +0300 Subject: [PATCH 014/125] 8153994: Compiler tests should be correctly marked with @module Reviewed-by: kvn --- hotspot/test/compiler/codecache/jmx/PoolsIndependenceTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/test/compiler/codecache/jmx/PoolsIndependenceTest.java b/hotspot/test/compiler/codecache/jmx/PoolsIndependenceTest.java index 97b21431caf..5b5ee81c2d0 100644 --- a/hotspot/test/compiler/codecache/jmx/PoolsIndependenceTest.java +++ b/hotspot/test/compiler/codecache/jmx/PoolsIndependenceTest.java @@ -38,6 +38,7 @@ import sun.hotspot.code.BlobType; /* * @test PoolsIndependenceTest * @modules java.base/jdk.internal.misc + * java.management * @library /testlibrary /test/lib * @build PoolsIndependenceTest * @run main ClassFileInstaller sun.hotspot.WhiteBox From 343a9e76a88282cb7e58adfbffbbb8e6e8d8bbab Mon Sep 17 00:00:00 2001 From: Josef Eisl Date: Tue, 31 May 2016 17:08:18 +0000 Subject: [PATCH 015/125] 8157292: [JVMCI] add missing test files from 8156034 Reviewed-by: iveresov --- ...ci.hotspot.services.HotSpotVMEventListener | 1 + ...m.ci.runtime.services.JVMCICompilerFactory | 1 + ...mciNotifyBootstrapFinishedEventTest.config | 1 + ...JvmciNotifyBootstrapFinishedEventTest.java | 82 +++++++++++++++++++ 4 files changed, 85 insertions(+) create mode 100644 hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.hotspot.services.HotSpotVMEventListener create mode 100644 hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.runtime.services.JVMCICompilerFactory create mode 100644 hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.config create mode 100644 hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java diff --git a/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.hotspot.services.HotSpotVMEventListener b/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.hotspot.services.HotSpotVMEventListener new file mode 100644 index 00000000000..2b70db58445 --- /dev/null +++ b/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.hotspot.services.HotSpotVMEventListener @@ -0,0 +1 @@ +compiler.jvmci.common.JVMCIHelpers$EmptyVMEventListener diff --git a/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.runtime.services.JVMCICompilerFactory b/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.runtime.services.JVMCICompilerFactory new file mode 100644 index 00000000000..5a88a1f4914 --- /dev/null +++ b/hotspot/test/compiler/jvmci/common/services/jdk.vm.ci.runtime.services.JVMCICompilerFactory @@ -0,0 +1 @@ +compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory diff --git a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.config b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.config new file mode 100644 index 00000000000..483de30ceab --- /dev/null +++ b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.config @@ -0,0 +1 @@ +compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest diff --git a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java new file mode 100644 index 00000000000..d1ed7a11737 --- /dev/null +++ b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java @@ -0,0 +1,82 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * @test + * @bug 8156034 + * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @library / /testlibrary + * @library ../common/patches + * @modules java.base/jdk.internal.org.objectweb.asm + * java.base/jdk.internal.org.objectweb.asm.tree + * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.code + * jdk.vm.ci/jdk.vm.ci.meta + * jdk.vm.ci/jdk.vm.ci.runtime + * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper + * @build compiler.jvmci.common.JVMCIHelpers + * compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest + * @run main jdk.test.lib.FileInstaller ../common/services/ ./META-INF/services/ + * @run main jdk.test.lib.FileInstaller ./JvmciNotifyBootstrapFinishedEventTest.config + * ./META-INF/services/jdk.vm.ci.hotspot.services.HotSpotVMEventListener + * @run main ClassFileInstaller + * compiler.jvmci.common.JVMCIHelpers$EmptyHotspotCompiler + * compiler.jvmci.common.JVMCIHelpers$EmptyCompilerFactory + * compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest + * jdk.test.lib.Asserts + * jdk.test.lib.Utils + * @run main/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI + * -Djvmci.Compiler=EmptyCompiler -Xbootclasspath/a:. + * -XX:+UseJVMCICompiler -XX:-BootstrapJVMCI + * -Dcompiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest.bootstrap=false + * compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest + * @run main/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI + * -Djvmci.Compiler=EmptyCompiler -Xbootclasspath/a:. + * -XX:+UseJVMCICompiler -XX:+BootstrapJVMCI + * -Dcompiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest.bootstrap=true + * compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest + */ + +package compiler.jvmci.events; + +import jdk.test.lib.Asserts; +import jdk.vm.ci.hotspot.services.HotSpotVMEventListener; + +public class JvmciNotifyBootstrapFinishedEventTest extends HotSpotVMEventListener { + private static final boolean BOOTSTRAP = Boolean + .getBoolean("compiler.jvmci.events.JvmciNotifyBootstrapFinishedEventTest.bootstrap"); + private static volatile int gotBoostrapNotification = 0; + + public static void main(String args[]) { + if (BOOTSTRAP) { + Asserts.assertEQ(gotBoostrapNotification, 1, "Did not receive expected number of bootstrap events"); + } else { + Asserts.assertEQ(gotBoostrapNotification, 0, "Got unexpected bootstrap event"); + } + } + + @Override + public void notifyBootstrapFinished() { + gotBoostrapNotification++; + } +} From bc9236dd30c9310f6c880b6a1747addf1638f086 Mon Sep 17 00:00:00 2001 From: Roland Schatz Date: Tue, 31 May 2016 20:43:12 +0000 Subject: [PATCH 016/125] 8157428: [JVMCI] remove MemoryAccessProvider.readUnsafeConstant from API Reviewed-by: iveresov --- .../HotSpotMemoryAccessProviderImpl.java | 14 +++++++++++-- .../jdk/vm/ci/meta/MemoryAccessProvider.java | 13 ------------ .../test/MemoryAccessProviderTest.java | 20 ------------------- 3 files changed, 12 insertions(+), 35 deletions(-) diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java index bcdd5d2d125..1d8828bb3bf 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java @@ -144,8 +144,18 @@ class HotSpotMemoryAccessProviderImpl implements HotSpotMemoryAccessProvider { return ret; } - @Override - public JavaConstant readUnsafeConstant(JavaKind kind, JavaConstant baseConstant, long displacement) { + /** + * Reads a value of this kind using a base address and a displacement. No bounds checking or + * type checking is performed. Returns {@code null} if the value is not available at this point. + * + * @param baseConstant the base address from which the value is read. + * @param displacement the displacement within the object in bytes + * @return the read value encapsulated in a {@link JavaConstant} object, or {@code null} if the + * value cannot be read. + * @throws IllegalArgumentException if {@code kind} is {@code null}, {@link JavaKind#Void}, not + * {@link JavaKind#Object} or not {@linkplain JavaKind#isPrimitive() primitive} kind + */ + JavaConstant readUnsafeConstant(JavaKind kind, JavaConstant baseConstant, long displacement) { if (kind == null) { throw new IllegalArgumentException("null JavaKind"); } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/MemoryAccessProvider.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/MemoryAccessProvider.java index aa9cade9ba9..81c5f395549 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/MemoryAccessProvider.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/MemoryAccessProvider.java @@ -27,19 +27,6 @@ package jdk.vm.ci.meta; */ public interface MemoryAccessProvider { - /** - * Reads a value of this kind using a base address and a displacement. No bounds checking or - * type checking is performed. Returns {@code null} if the value is not available at this point. - * - * @param base the base address from which the value is read. - * @param displacement the displacement within the object in bytes - * @return the read value encapsulated in a {@link JavaConstant} object, or {@code null} if the - * value cannot be read. - * @throws IllegalArgumentException if {@code kind} is {@code null}, {@link JavaKind#Void}, not - * {@link JavaKind#Object} or not {@linkplain JavaKind#isPrimitive() primitive} kind - */ - JavaConstant readUnsafeConstant(JavaKind kind, JavaConstant base, long displacement) throws IllegalArgumentException; - /** * Reads a primitive value using a base address and a displacement. * diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java index ff79b14c9a1..ed07e8af3a1 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java @@ -48,26 +48,6 @@ import jdk.vm.ci.runtime.JVMCI; public class MemoryAccessProviderTest { private static final MemoryAccessProvider PROVIDER = JVMCI.getRuntime().getHostJVMCIBackend().getConstantReflection().getMemoryAccessProvider(); - @Test(dataProvider = "positivePrimitive", dataProviderClass = MemoryAccessProviderData.class) - public void testPositiveReadUnsafeConstant(JavaKind kind, JavaConstant base, Long offset, Object expected, int bitsCount) { - Assert.assertEquals(PROVIDER.readUnsafeConstant(kind, base, offset), expected, "Failed to read constant"); - } - - @Test(dataProvider = "positivePrimitive", dataProviderClass = MemoryAccessProviderData.class, expectedExceptions = {IllegalArgumentException.class}) - public void testReadUnsafeConstantNullBase(JavaKind kind, JavaConstant base, Long offset, Object expected, int bitsCount) { - PROVIDER.readUnsafeConstant(kind, null, offset); - } - - @Test(dataProvider = "positivePrimitive", dataProviderClass = MemoryAccessProviderData.class, expectedExceptions = {IllegalArgumentException.class}) - public void testNegativeReadUnsafeConstantNullKind(JavaKind kind, JavaConstant base, Long offset, Object expected, int bitsCount) { - Assert.assertNull(PROVIDER.readUnsafeConstant(null, base, offset), "Expected null return"); - } - - @Test(dataProvider = "negative", dataProviderClass = MemoryAccessProviderData.class, expectedExceptions = {IllegalArgumentException.class}) - public void testNegativeReadUnsafeConstant(JavaKind kind, JavaConstant base) { - PROVIDER.readUnsafeConstant(kind, base, 0L); - } - @Test(dataProvider = "positivePrimitive", dataProviderClass = MemoryAccessProviderData.class) public void testPositiveReadPrimitiveConstant(JavaKind kind, Constant base, Long offset, Object expected, int bitsCount) { Assert.assertEquals(PROVIDER.readPrimitiveConstant(kind, base, offset, bitsCount), expected, "Failed to read constant"); From d1cfec7f7eaa5cc1b284187060462afc09a8d2fe Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Wed, 1 Jun 2016 14:22:18 +0200 Subject: [PATCH 017/125] 8155046: Parse::Block construction using undefined behavior Blocks should be created via constructor and placement new. Reviewed-by: kvn --- hotspot/src/share/vm/opto/parse.hpp | 7 ++----- hotspot/src/share/vm/opto/parse1.cpp | 18 +++++++++++------- 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/hotspot/src/share/vm/opto/parse.hpp b/hotspot/src/share/vm/opto/parse.hpp index cb9a3e3f104..c2b88595333 100644 --- a/hotspot/src/share/vm/opto/parse.hpp +++ b/hotspot/src/share/vm/opto/parse.hpp @@ -166,14 +166,11 @@ class Parse : public GraphKit { int _all_successors; // Include exception paths also. Block** _successors; - // Use init_node/init_graph to initialize Blocks. - // Block() : _live_locals((uintptr_t*)NULL,0) { ShouldNotReachHere(); } - Block() : _live_locals() { ShouldNotReachHere(); } - public: // Set up the block data structure itself. - void init_node(Parse* outer, int po); + Block(Parse* outer, int rpo); + // Set up the block's relations to other blocks. void init_graph(Parse* outer); diff --git a/hotspot/src/share/vm/opto/parse1.cpp b/hotspot/src/share/vm/opto/parse1.cpp index 80885d9a836..b2044d3d5e1 100644 --- a/hotspot/src/share/vm/opto/parse1.cpp +++ b/hotspot/src/share/vm/opto/parse1.cpp @@ -1235,29 +1235,33 @@ void Parse::init_blocks() { // Create the blocks. _block_count = flow()->block_count(); _blocks = NEW_RESOURCE_ARRAY(Block, _block_count); - Copy::zero_to_bytes(_blocks, sizeof(Block)*_block_count); - - int rpo; // Initialize the structs. - for (rpo = 0; rpo < block_count(); rpo++) { + for (int rpo = 0; rpo < block_count(); rpo++) { Block* block = rpo_at(rpo); - block->init_node(this, rpo); + new(block) Block(this, rpo); } // Collect predecessor and successor information. - for (rpo = 0; rpo < block_count(); rpo++) { + for (int rpo = 0; rpo < block_count(); rpo++) { Block* block = rpo_at(rpo); block->init_graph(this); } } //-------------------------------init_node------------------------------------- -void Parse::Block::init_node(Parse* outer, int rpo) { +Parse::Block::Block(Parse* outer, int rpo) : _live_locals() { _flow = outer->flow()->rpo_at(rpo); _pred_count = 0; _preds_parsed = 0; _count = 0; + _is_parsed = false; + _is_handler = false; + _has_merged_backedge = false; + _start_map = NULL; + _num_successors = 0; + _all_successors = 0; + _successors = NULL; assert(pred_count() == 0 && preds_parsed() == 0, "sanity"); assert(!(is_merged() || is_parsed() || is_handler() || has_merged_backedge()), "sanity"); assert(_live_locals.size() == 0, "sanity"); From e4102fbe6739a22b6116758578b687ba1549cf04 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Wed, 1 Jun 2016 16:36:44 +0200 Subject: [PATCH 018/125] 8157842: indexOfChar intrinsic is not emitted on x86 Matcher::match_rule_supported() should check for !UseSSE42Intrinsics. Reviewed-by: roland, rbackman, shade, kvn --- hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp | 10 ---------- hotspot/src/cpu/x86/vm/x86.ad | 2 +- 2 files changed, 1 insertion(+), 11 deletions(-) diff --git a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp index e3425c400ca..f9b42ec3ea1 100644 --- a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp @@ -7046,7 +7046,6 @@ void MacroAssembler::string_indexofC8(Register str1, Register str2, int ae) { ShortBranchVerifier sbv(this); assert(UseSSE42Intrinsics, "SSE4.2 intrinsics are required"); - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); assert(ae != StrIntrinsicNode::LU, "Invalid encoding"); // This method uses the pcmpestri instruction with bound registers @@ -7225,7 +7224,6 @@ void MacroAssembler::string_indexof(Register str1, Register str2, int ae) { ShortBranchVerifier sbv(this); assert(UseSSE42Intrinsics, "SSE4.2 intrinsics are required"); - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); assert(ae != StrIntrinsicNode::LU, "Invalid encoding"); // @@ -7543,7 +7541,6 @@ void MacroAssembler::string_indexof_char(Register str1, Register cnt1, Register XMMRegister vec1, XMMRegister vec2, XMMRegister vec3, Register tmp) { ShortBranchVerifier sbv(this); assert(UseSSE42Intrinsics, "SSE4.2 intrinsics are required"); - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); int stride = 8; @@ -7723,7 +7720,6 @@ void MacroAssembler::string_compare(Register str1, Register str2, } if (UseAVX >= 2 && UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); Label COMPARE_WIDE_VECTORS, VECTOR_NOT_EQUAL, COMPARE_WIDE_TAIL, COMPARE_SMALL_STR; Label COMPARE_WIDE_VECTORS_LOOP, COMPARE_16_CHARS, COMPARE_INDEX_CHAR; Label COMPARE_WIDE_VECTORS_LOOP_AVX2; @@ -7891,7 +7887,6 @@ void MacroAssembler::string_compare(Register str1, Register str2, bind(COMPARE_SMALL_STR); } else if (UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); Label COMPARE_WIDE_VECTORS, VECTOR_NOT_EQUAL, COMPARE_TAIL; int pcmpmask = 0x19; // Setup to compare 8-char (16-byte) vectors, @@ -8179,7 +8174,6 @@ void MacroAssembler::has_negatives(Register ary1, Register len, // Fallthru to tail compare } else if (UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be for SSE4.2 intrinsics to be available"); // With SSE4.2, use double quad vector compare Label COMPARE_WIDE_VECTORS, COMPARE_TAIL; @@ -8383,7 +8377,6 @@ void MacroAssembler::arrays_equals(bool is_array_equ, Register ary1, Register ar movl(limit, result); // Fallthru to tail compare } else if (UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); // With SSE4.2, use double quad vector compare Label COMPARE_WIDE_VECTORS, COMPARE_TAIL; @@ -8747,7 +8740,6 @@ void MacroAssembler::encode_iso_array(Register src, Register dst, Register len, negptr(len); if (UseSSE42Intrinsics || UseAVX >= 2) { - assert(UseSSE42Intrinsics ? UseSSE >= 4 : true, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); Label L_chars_8_check, L_copy_8_chars, L_copy_8_chars_exit; Label L_chars_16_check, L_copy_16_chars, L_copy_16_chars_exit; @@ -10881,7 +10873,6 @@ void MacroAssembler::char_array_compress(Register src, Register dst, Register le clear_vector_masking(); // closing of the stub context for programming mask registers } if (UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); Label copy_32_loop, copy_16, copy_tail; bind(below_threshold); @@ -11045,7 +11036,6 @@ void MacroAssembler::byte_array_inflate(Register src, Register dst, Register len clear_vector_masking(); // closing of the stub context for programming mask registers } if (UseSSE42Intrinsics) { - assert(UseSSE >= 4, "SSE4 must be enabled for SSE4.2 intrinsics to be available"); Label copy_16_loop, copy_8_loop, copy_bytes, copy_new_tail, copy_tail; movl(tmp2, len); diff --git a/hotspot/src/cpu/x86/vm/x86.ad b/hotspot/src/cpu/x86/vm/x86.ad index ce14f4c742e..17abe70af79 100644 --- a/hotspot/src/cpu/x86/vm/x86.ad +++ b/hotspot/src/cpu/x86/vm/x86.ad @@ -1718,7 +1718,7 @@ const bool Matcher::match_rule_supported(int opcode) { ret_value = false; break; case Op_StrIndexOfChar: - if (!(UseSSE > 4)) + if (!UseSSE42Intrinsics) ret_value = false; break; case Op_OnSpinWait: From 35f9db149b800cce3769e91f2986d6866dfc2085 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Thu, 2 Jun 2016 08:46:52 +0200 Subject: [PATCH 019/125] 8156760: VM crashes if -XX:-ReduceInitialCardMarks is set Fixed several compiler crashes with disabled ReduceInitialCardMarks. Reviewed-by: roland, minqi, dlong, tschatzl, kvn --- .../share/vm/gc/g1/g1CollectedHeap.inline.hpp | 2 +- .../src/share/vm/gc/shared/collectedHeap.cpp | 2 +- hotspot/src/share/vm/opto/arraycopynode.cpp | 22 +++-- hotspot/src/share/vm/opto/arraycopynode.hpp | 6 +- hotspot/src/share/vm/opto/graphKit.cpp | 11 ++- hotspot/src/share/vm/opto/macro.cpp | 88 +++++++++++-------- hotspot/src/share/vm/opto/memnode.cpp | 6 +- .../TestEliminatedArrayCopyDeopt.java | 6 +- .../TestInstanceCloneAsLoadsStores.java | 6 +- 9 files changed, 91 insertions(+), 58 deletions(-) diff --git a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.inline.hpp b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.inline.hpp index 05b24e0bf52..3a66fad03a5 100644 --- a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.inline.hpp +++ b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.inline.hpp @@ -109,7 +109,7 @@ inline void G1CollectedHeap::old_set_remove(HeapRegion* hr) { _old_set.remove(hr); } -// It dirties the cards that cover the block so that so that the post +// It dirties the cards that cover the block so that the post // write barrier never queues anything when updating objects on this // block. It is assumed (and in fact we assert) that the block // belongs to a young region. diff --git a/hotspot/src/share/vm/gc/shared/collectedHeap.cpp b/hotspot/src/share/vm/gc/shared/collectedHeap.cpp index e40326066fe..1ad500c890a 100644 --- a/hotspot/src/share/vm/gc/shared/collectedHeap.cpp +++ b/hotspot/src/share/vm/gc/shared/collectedHeap.cpp @@ -386,7 +386,7 @@ size_t CollectedHeap::max_tlab_size() const { // initialized by this point, a fact that we assert when doing the // card-mark.) // (c) G1CollectedHeap(G1) uses two kinds of write barriers. When a -// G1 concurrent marking is in progress an SATB (pre-write-)barrier is +// G1 concurrent marking is in progress an SATB (pre-write-)barrier // is used to remember the pre-value of any store. Initializing // stores will not need this barrier, so we need not worry about // compensating for the missing pre-barrier here. Turning now diff --git a/hotspot/src/share/vm/opto/arraycopynode.cpp b/hotspot/src/share/vm/opto/arraycopynode.cpp index c86bbc02ab4..08334b22597 100644 --- a/hotspot/src/share/vm/opto/arraycopynode.cpp +++ b/hotspot/src/share/vm/opto/arraycopynode.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -204,7 +204,8 @@ Node* ArrayCopyNode::try_clone_instance(PhaseGVN *phase, bool can_reshape, int c } if (!finish_transform(phase, can_reshape, ctl, mem)) { - return NULL; + // Return NodeSentinel to indicate that the transform failed + return NodeSentinel; } return mem; @@ -222,6 +223,7 @@ bool ArrayCopyNode::prepare_array_copy(PhaseGVN *phase, bool can_reshape, Node* dest = in(ArrayCopyNode::Dest); const Type* src_type = phase->type(src); const TypeAryPtr* ary_src = src_type->isa_aryptr(); + assert(ary_src != NULL, "should be an array copy/clone"); if (is_arraycopy() || is_copyofrange() || is_copyof()) { const Type* dest_type = phase->type(dest); @@ -520,7 +522,7 @@ Node *ArrayCopyNode::Ideal(PhaseGVN *phase, bool can_reshape) { Node* mem = try_clone_instance(phase, can_reshape, count); if (mem != NULL) { - return mem; + return (mem == NodeSentinel) ? NULL : mem; } Node* adr_src = NULL; @@ -627,31 +629,37 @@ bool ArrayCopyNode::may_modify(const TypeOopPtr *t_oop, PhaseTransform *phase) { return CallNode::may_modify_arraycopy_helper(dest_t, t_oop, phase); } -bool ArrayCopyNode::may_modify_helper(const TypeOopPtr *t_oop, Node* n, PhaseTransform *phase) { +bool ArrayCopyNode::may_modify_helper(const TypeOopPtr *t_oop, Node* n, PhaseTransform *phase, ArrayCopyNode*& ac) { if (n->is_Proj()) { n = n->in(0); if (n->is_Call() && n->as_Call()->may_modify(t_oop, phase)) { + if (n->isa_ArrayCopy() != NULL) { + ac = n->as_ArrayCopy(); + } return true; } } return false; } -bool ArrayCopyNode::may_modify(const TypeOopPtr *t_oop, MemBarNode* mb, PhaseTransform *phase) { +bool ArrayCopyNode::may_modify(const TypeOopPtr *t_oop, MemBarNode* mb, PhaseTransform *phase, ArrayCopyNode*& ac) { Node* mem = mb->in(TypeFunc::Memory); if (mem->is_MergeMem()) { Node* n = mem->as_MergeMem()->memory_at(Compile::AliasIdxRaw); - if (may_modify_helper(t_oop, n, phase)) { + if (may_modify_helper(t_oop, n, phase, ac)) { return true; } else if (n->is_Phi()) { for (uint i = 1; i < n->req(); i++) { if (n->in(i) != NULL) { - if (may_modify_helper(t_oop, n->in(i), phase)) { + if (may_modify_helper(t_oop, n->in(i), phase, ac)) { return true; } } } + } else if (n->Opcode() == Op_StoreCM) { + // Ignore card mark stores + return may_modify_helper(t_oop, n->in(MemNode::Memory), phase, ac); } } diff --git a/hotspot/src/share/vm/opto/arraycopynode.hpp b/hotspot/src/share/vm/opto/arraycopynode.hpp index e17ea1f57a6..c0f635eb284 100644 --- a/hotspot/src/share/vm/opto/arraycopynode.hpp +++ b/hotspot/src/share/vm/opto/arraycopynode.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -107,7 +107,7 @@ private: BasicType copy_type, const Type* value_type, int count); bool finish_transform(PhaseGVN *phase, bool can_reshape, Node* ctl, Node *mem); - static bool may_modify_helper(const TypeOopPtr *t_oop, Node* n, PhaseTransform *phase); + static bool may_modify_helper(const TypeOopPtr *t_oop, Node* n, PhaseTransform *phase, ArrayCopyNode*& ac); public: @@ -162,7 +162,7 @@ public: bool is_alloc_tightly_coupled() const { return _alloc_tightly_coupled; } - static bool may_modify(const TypeOopPtr *t_oop, MemBarNode* mb, PhaseTransform *phase); + static bool may_modify(const TypeOopPtr *t_oop, MemBarNode* mb, PhaseTransform *phase, ArrayCopyNode*& ac); bool modifies(intptr_t offset_lo, intptr_t offset_hi, PhaseTransform* phase, bool must_modify); #ifndef PRODUCT diff --git a/hotspot/src/share/vm/opto/graphKit.cpp b/hotspot/src/share/vm/opto/graphKit.cpp index 3a7d21ac897..acb4174bcf1 100644 --- a/hotspot/src/share/vm/opto/graphKit.cpp +++ b/hotspot/src/share/vm/opto/graphKit.cpp @@ -4306,8 +4306,15 @@ void GraphKit::g1_write_barrier_post(Node* oop_store, } __ end_if(); } __ end_if(); } else { - // Object.clone() instrinsic uses this path. - g1_mark_card(ideal, card_adr, oop_store, alias_idx, index, index_adr, buffer, tf); + // The Object.clone() intrinsic uses this path if !ReduceInitialCardMarks. + // We don't need a barrier here if the destination is a newly allocated object + // in Eden. Otherwise, GC verification breaks because we assume that cards in Eden + // are set to 'g1_young_gen' (see G1SATBCardTableModRefBS::verify_g1_young_region()). + assert(!use_ReduceInitialCardMarks(), "can only happen with card marking"); + Node* card_val = __ load(__ ctrl(), card_adr, TypeInt::INT, T_BYTE, Compile::AliasIdxRaw); + __ if_then(card_val, BoolTest::ne, young_card); { + g1_mark_card(ideal, card_adr, oop_store, alias_idx, index, index_adr, buffer, tf); + } __ end_if(); } // Final sync IdealKit and GraphKit. diff --git a/hotspot/src/share/vm/opto/macro.cpp b/hotspot/src/share/vm/opto/macro.cpp index 106257aae5b..993f60f7234 100644 --- a/hotspot/src/share/vm/opto/macro.cpp +++ b/hotspot/src/share/vm/opto/macro.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -32,6 +32,7 @@ #include "opto/cfgnode.hpp" #include "opto/compile.hpp" #include "opto/convertnode.hpp" +#include "opto/graphKit.hpp" #include "opto/locknode.hpp" #include "opto/loopnode.hpp" #include "opto/macro.hpp" @@ -263,41 +264,58 @@ void PhaseMacroExpand::eliminate_card_mark(Node* p2x) { // checks if the store done to a different from the value's region. // And replace Cmp with #0 (false) to collapse G1 post barrier. Node* xorx = p2x->find_out_with(Op_XorX); - assert(xorx != NULL, "missing G1 post barrier"); - Node* shift = xorx->unique_out(); - Node* cmpx = shift->unique_out(); - assert(cmpx->is_Cmp() && cmpx->unique_out()->is_Bool() && - cmpx->unique_out()->as_Bool()->_test._test == BoolTest::ne, - "missing region check in G1 post barrier"); - _igvn.replace_node(cmpx, makecon(TypeInt::CC_EQ)); + if (xorx != NULL) { + Node* shift = xorx->unique_out(); + Node* cmpx = shift->unique_out(); + assert(cmpx->is_Cmp() && cmpx->unique_out()->is_Bool() && + cmpx->unique_out()->as_Bool()->_test._test == BoolTest::ne, + "missing region check in G1 post barrier"); + _igvn.replace_node(cmpx, makecon(TypeInt::CC_EQ)); - // Remove G1 pre barrier. + // Remove G1 pre barrier. - // Search "if (marking != 0)" check and set it to "false". - // There is no G1 pre barrier if previous stored value is NULL - // (for example, after initialization). - if (this_region->is_Region() && this_region->req() == 3) { - int ind = 1; - if (!this_region->in(ind)->is_IfFalse()) { - ind = 2; - } - if (this_region->in(ind)->is_IfFalse()) { - Node* bol = this_region->in(ind)->in(0)->in(1); - assert(bol->is_Bool(), ""); - cmpx = bol->in(1); - if (bol->as_Bool()->_test._test == BoolTest::ne && - cmpx->is_Cmp() && cmpx->in(2) == intcon(0) && - cmpx->in(1)->is_Load()) { - Node* adr = cmpx->in(1)->as_Load()->in(MemNode::Address); - const int marking_offset = in_bytes(JavaThread::satb_mark_queue_offset() + - SATBMarkQueue::byte_offset_of_active()); - if (adr->is_AddP() && adr->in(AddPNode::Base) == top() && - adr->in(AddPNode::Address)->Opcode() == Op_ThreadLocal && - adr->in(AddPNode::Offset) == MakeConX(marking_offset)) { - _igvn.replace_node(cmpx, makecon(TypeInt::CC_EQ)); + // Search "if (marking != 0)" check and set it to "false". + // There is no G1 pre barrier if previous stored value is NULL + // (for example, after initialization). + if (this_region->is_Region() && this_region->req() == 3) { + int ind = 1; + if (!this_region->in(ind)->is_IfFalse()) { + ind = 2; + } + if (this_region->in(ind)->is_IfFalse()) { + Node* bol = this_region->in(ind)->in(0)->in(1); + assert(bol->is_Bool(), ""); + cmpx = bol->in(1); + if (bol->as_Bool()->_test._test == BoolTest::ne && + cmpx->is_Cmp() && cmpx->in(2) == intcon(0) && + cmpx->in(1)->is_Load()) { + Node* adr = cmpx->in(1)->as_Load()->in(MemNode::Address); + const int marking_offset = in_bytes(JavaThread::satb_mark_queue_offset() + + SATBMarkQueue::byte_offset_of_active()); + if (adr->is_AddP() && adr->in(AddPNode::Base) == top() && + adr->in(AddPNode::Address)->Opcode() == Op_ThreadLocal && + adr->in(AddPNode::Offset) == MakeConX(marking_offset)) { + _igvn.replace_node(cmpx, makecon(TypeInt::CC_EQ)); + } } } } + } else { + assert(!GraphKit::use_ReduceInitialCardMarks(), "can only happen with card marking"); + // This is a G1 post barrier emitted by the Object.clone() intrinsic. + // Search for the CastP2X->URShiftX->AddP->LoadB->Cmp path which checks if the card + // is marked as young_gen and replace the Cmp with 0 (false) to collapse the barrier. + Node* shift = p2x->find_out_with(Op_URShiftX); + assert(shift != NULL, "missing G1 post barrier"); + Node* addp = shift->unique_out(); + Node* load = addp->find_out_with(Op_LoadB); + assert(load != NULL, "missing G1 post barrier"); + Node* cmpx = load->unique_out(); + assert(cmpx->is_Cmp() && cmpx->unique_out()->is_Bool() && + cmpx->unique_out()->as_Bool()->_test._test == BoolTest::ne, + "missing card value check in G1 post barrier"); + _igvn.replace_node(cmpx, makecon(TypeInt::CC_EQ)); + // There is no G1 pre barrier in this case } // Now CastP2X can be removed since it is used only on dead path // which currently still alive until igvn optimize it. @@ -326,17 +344,15 @@ static Node *scan_mem_chain(Node *mem, int alias_idx, int offset, Node *start_me CallNode *call = in->as_Call(); if (call->may_modify(tinst, phase)) { assert(call->is_ArrayCopy(), "ArrayCopy is the only call node that doesn't make allocation escape"); - if (call->as_ArrayCopy()->modifies(offset, offset, phase, false)) { return in; } } mem = in->in(TypeFunc::Memory); } else if (in->is_MemBar()) { - if (ArrayCopyNode::may_modify(tinst, in->as_MemBar(), phase)) { - assert(in->in(0)->is_Proj() && in->in(0)->in(0)->is_ArrayCopy(), "should be arraycopy"); - ArrayCopyNode* ac = in->in(0)->in(0)->as_ArrayCopy(); - assert(ac->is_clonebasic(), "Only basic clone is a non escaping clone"); + ArrayCopyNode* ac = NULL; + if (ArrayCopyNode::may_modify(tinst, in->as_MemBar(), phase, ac)) { + assert(ac != NULL && ac->is_clonebasic(), "Only basic clone is a non escaping clone"); return ac; } mem = in->in(TypeFunc::Memory); diff --git a/hotspot/src/share/vm/opto/memnode.cpp b/hotspot/src/share/vm/opto/memnode.cpp index d4a4e3ab9e4..f0d588a6d1a 100644 --- a/hotspot/src/share/vm/opto/memnode.cpp +++ b/hotspot/src/share/vm/opto/memnode.cpp @@ -160,7 +160,8 @@ Node *MemNode::optimize_simple_memory_chain(Node *mchain, const TypeOopPtr *t_oo } } } else if (proj_in->is_MemBar()) { - if (ArrayCopyNode::may_modify(t_oop, proj_in->as_MemBar(), phase)) { + ArrayCopyNode* ac = NULL; + if (ArrayCopyNode::may_modify(t_oop, proj_in->as_MemBar(), phase, ac)) { break; } result = proj_in->in(TypeFunc::Memory); @@ -657,7 +658,8 @@ Node* MemNode::find_previous_store(PhaseTransform* phase) { continue; // (a) advance through independent call memory } } else if (mem->is_Proj() && mem->in(0)->is_MemBar()) { - if (ArrayCopyNode::may_modify(addr_t, mem->in(0)->as_MemBar(), phase)) { + ArrayCopyNode* ac = NULL; + if (ArrayCopyNode::may_modify(addr_t, mem->in(0)->as_MemBar(), phase, ac)) { break; } mem = mem->in(0)->in(TypeFunc::Memory); diff --git a/hotspot/test/compiler/arraycopy/TestEliminatedArrayCopyDeopt.java b/hotspot/test/compiler/arraycopy/TestEliminatedArrayCopyDeopt.java index 00e8fed9901..fb98c652c71 100644 --- a/hotspot/test/compiler/arraycopy/TestEliminatedArrayCopyDeopt.java +++ b/hotspot/test/compiler/arraycopy/TestEliminatedArrayCopyDeopt.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,10 +23,10 @@ /* * @test - * @bug 8130847 + * @bug 8130847 8156760 * @summary Eliminated instance/array written to by an array copy variant must be correctly initialized when reallocated at a deopt * @run main/othervm -XX:-BackgroundCompilation -XX:-UseOnStackReplacement TestEliminatedArrayCopyDeopt - * + * @run main/othervm -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:+IgnoreUnrecognizedVMOptions -XX:-ReduceInitialCardMarks TestEliminatedArrayCopyDeopt */ // Test that if an ArrayCopy node is eliminated because it doesn't diff --git a/hotspot/test/compiler/arraycopy/TestInstanceCloneAsLoadsStores.java b/hotspot/test/compiler/arraycopy/TestInstanceCloneAsLoadsStores.java index 8e95036f550..640c6862762 100644 --- a/hotspot/test/compiler/arraycopy/TestInstanceCloneAsLoadsStores.java +++ b/hotspot/test/compiler/arraycopy/TestInstanceCloneAsLoadsStores.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,12 +23,12 @@ /* * @test - * @bug 6700100 + * @bug 6700100 8156760 * @summary small instance clone as loads/stores * @compile TestInstanceCloneAsLoadsStores.java TestInstanceCloneUtils.java * @run main/othervm -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:CompileCommand=dontinline,TestInstanceCloneAsLoadsStores::m* TestInstanceCloneAsLoadsStores * @run main/othervm -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:CompileCommand=dontinline,TestInstanceCloneAsLoadsStores::m* -XX:+IgnoreUnrecognizedVMOptions -XX:+StressArrayCopyMacroNode TestInstanceCloneAsLoadsStores - * + * @run main/othervm -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:CompileCommand=dontinline,TestInstanceCloneAsLoadsStores::m* -XX:+IgnoreUnrecognizedVMOptions -XX:-ReduceInitialCardMarks TestInstanceCloneAsLoadsStores */ public class TestInstanceCloneAsLoadsStores extends TestInstanceCloneUtils { From f92cc0c83645be1580a5d3400931ab4d30d25a0a Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Thu, 2 Jun 2016 13:19:05 +0200 Subject: [PATCH 020/125] 8158214: Crash with "assert(VM_Version::supports_sse4_1()) failed" if UseSSE < 4 is set Do not emit unsupported SSE 4.1 instructions in CRC32 intrinsic. Reviewed-by: kvn, zmajo --- hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp | 8 +++- hotspot/src/cpu/x86/vm/vm_version_x86.cpp | 6 +-- .../compiler/cpuflags/TestSSE4Disabled.java | 37 +++++++++++++++++++ 3 files changed, 47 insertions(+), 4 deletions(-) create mode 100644 hotspot/test/compiler/cpuflags/TestSSE4Disabled.java diff --git a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp index f9b42ec3ea1..9b52535459a 100644 --- a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp @@ -10151,7 +10151,13 @@ void MacroAssembler::kernel_crc32(Register crc, Register buf, Register len, Regi movdqa(xmm1, Address(buf, 0)); movdl(rax, xmm1); xorl(crc, rax); - pinsrd(xmm1, crc, 0); + if (VM_Version::supports_sse4_1()) { + pinsrd(xmm1, crc, 0); + } else { + pinsrw(xmm1, crc, 0); + shrl(crc, 16); + pinsrw(xmm1, crc, 1); + } addptr(buf, 16); subl(len, 4); // len > 0 jcc(Assembler::less, L_fold_tail); diff --git a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp index 65acaffe4cf..ef78e640fd8 100644 --- a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp +++ b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp @@ -658,7 +658,7 @@ void VM_Version::get_processor_features() { FLAG_SET_DEFAULT(UseAESCTRIntrinsics, false); } } else { - if(supports_sse4_1() && UseSSE >= 4) { + if(supports_sse4_1()) { if (FLAG_IS_DEFAULT(UseAESCTRIntrinsics)) { FLAG_SET_DEFAULT(UseAESCTRIntrinsics, true); } @@ -970,7 +970,7 @@ void VM_Version::get_processor_features() { UseXmmI2D = false; } } - if (supports_sse4_2() && UseSSE >= 4) { + if (supports_sse4_2()) { if (FLAG_IS_DEFAULT(UseSSE42Intrinsics)) { FLAG_SET_DEFAULT(UseSSE42Intrinsics, true); } @@ -1050,7 +1050,7 @@ void VM_Version::get_processor_features() { UseUnalignedLoadStores = true; // use movdqu on newest Intel cpus } } - if (supports_sse4_2() && UseSSE >= 4) { + if (supports_sse4_2()) { if (FLAG_IS_DEFAULT(UseSSE42Intrinsics)) { FLAG_SET_DEFAULT(UseSSE42Intrinsics, true); } diff --git a/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java b/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java new file mode 100644 index 00000000000..4bd655f6cac --- /dev/null +++ b/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java @@ -0,0 +1,37 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +/* + * @test TestSSE4Disabled + * @bug 8158214 + * @requires (os.simpleArch == "x64") + * @summary Test correct execution without SSE 4. + * @run main/othervm -Xcomp -XX:UseSSE=3 TestSSE4Disabled + */ +public class TestSSE4Disabled { + public static void main(String args[]) { + System.out.println("Passed"); + } +} + From 2e85bb45ff98e01846da8434010a32ff65c421ba Mon Sep 17 00:00:00 2001 From: Fei Yang Date: Thu, 2 Jun 2016 21:12:46 +0800 Subject: [PATCH 021/125] 8149418: AArch64: replace tst+br with tbz instruction when tst's constant operand is 2 power Replace tst+br with tbz instruction when tst's constant operand is 2 power Reviewed-by: aph --- hotspot/src/cpu/aarch64/vm/c1_Runtime1_aarch64.cpp | 3 +-- hotspot/src/cpu/aarch64/vm/interp_masm_aarch64.cpp | 13 +++++-------- .../vm/templateInterpreterGenerator_aarch64.cpp | 6 ++---- .../src/cpu/aarch64/vm/templateTable_aarch64.cpp | 3 +-- 4 files changed, 9 insertions(+), 16 deletions(-) diff --git a/hotspot/src/cpu/aarch64/vm/c1_Runtime1_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/c1_Runtime1_aarch64.cpp index b1df18ade63..7752e7bfee3 100644 --- a/hotspot/src/cpu/aarch64/vm/c1_Runtime1_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/c1_Runtime1_aarch64.cpp @@ -944,8 +944,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { Register t = r5; __ load_klass(t, r0); __ ldrw(t, Address(t, Klass::access_flags_offset())); - __ tst(t, JVM_ACC_HAS_FINALIZER); - __ br(Assembler::NE, register_finalizer); + __ tbnz(t, exact_log2(JVM_ACC_HAS_FINALIZER), register_finalizer); __ ret(lr); __ bind(register_finalizer); diff --git a/hotspot/src/cpu/aarch64/vm/interp_masm_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/interp_masm_aarch64.cpp index 22712102137..bc8699e4a6b 100644 --- a/hotspot/src/cpu/aarch64/vm/interp_masm_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/interp_masm_aarch64.cpp @@ -93,10 +93,8 @@ void InterpreterMacroAssembler::check_and_handle_popframe(Register java_thread) // This method is only called just after the call into the vm in // call_VM_base, so the arg registers are available. ldrw(rscratch1, Address(rthread, JavaThread::popframe_condition_offset())); - tstw(rscratch1, JavaThread::popframe_pending_bit); - br(Assembler::EQ, L); - tstw(rscratch1, JavaThread::popframe_processing_bit); - br(Assembler::NE, L); + tbz(rscratch1, exact_log2(JavaThread::popframe_pending_bit), L); + tbnz(rscratch1, exact_log2(JavaThread::popframe_processing_bit), L); // Call Interpreter::remove_activation_preserving_args_entry() to get the // address of the same-named entrypoint in the generated interpreter code. call_VM_leaf(CAST_FROM_FN_PTR(address, Interpreter::remove_activation_preserving_args_entry)); @@ -505,8 +503,7 @@ void InterpreterMacroAssembler::remove_activation( // get method access flags ldr(r1, Address(rfp, frame::interpreter_frame_method_offset * wordSize)); ldr(r2, Address(r1, Method::access_flags_offset())); - tst(r2, JVM_ACC_SYNCHRONIZED); - br(Assembler::EQ, unlocked); + tbz(r2, exact_log2(JVM_ACC_SYNCHRONIZED), unlocked); // Don't unlock anything if the _do_not_unlock_if_synchronized flag // is set. @@ -1582,8 +1579,8 @@ void InterpreterMacroAssembler::profile_obj_type(Register obj, const Address& md // do. The unknown bit may have been // set already but no need to check. - tst(obj, TypeEntries::type_unknown); - br(Assembler::NE, next); // already unknown. Nothing to do anymore. + tbnz(obj, exact_log2(TypeEntries::type_unknown), next); + // already unknown. Nothing to do anymore. ldr(rscratch1, mdo_addr); cbz(rscratch1, none); diff --git a/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp index e78276ed8a7..f24536daf75 100644 --- a/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp @@ -1242,8 +1242,7 @@ address TemplateInterpreterGenerator::generate_native_entry(bool synchronized) { { Label L; __ ldrw(t, Address(rmethod, Method::access_flags_offset())); - __ tst(t, JVM_ACC_STATIC); - __ br(Assembler::EQ, L); + __ tbz(t, exact_log2(JVM_ACC_STATIC), L); // get mirror __ load_mirror(t, rmethod); // copy mirror into activation frame @@ -1435,8 +1434,7 @@ address TemplateInterpreterGenerator::generate_native_entry(bool synchronized) { { Label L; __ ldrw(t, Address(rmethod, Method::access_flags_offset())); - __ tst(t, JVM_ACC_SYNCHRONIZED); - __ br(Assembler::EQ, L); + __ tbz(t, exact_log2(JVM_ACC_SYNCHRONIZED), L); // the code below should be shared with interpreter macro // assembler implementation { diff --git a/hotspot/src/cpu/aarch64/vm/templateTable_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/templateTable_aarch64.cpp index 5c1a98463bf..68827fc2378 100644 --- a/hotspot/src/cpu/aarch64/vm/templateTable_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/templateTable_aarch64.cpp @@ -2190,9 +2190,8 @@ void TemplateTable::_return(TosState state) __ ldr(c_rarg1, aaddress(0)); __ load_klass(r3, c_rarg1); __ ldrw(r3, Address(r3, Klass::access_flags_offset())); - __ tst(r3, JVM_ACC_HAS_FINALIZER); Label skip_register_finalizer; - __ br(Assembler::EQ, skip_register_finalizer); + __ tbz(r3, exact_log2(JVM_ACC_HAS_FINALIZER), skip_register_finalizer); __ call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::register_finalizer), c_rarg1); From fce865ff45ed37769decf1cf1ff60d2939e84397 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Thu, 2 Jun 2016 17:52:42 +0000 Subject: [PATCH 022/125] 8158000: [JVMCI] remove unused ParseClosure class Reviewed-by: kvn --- hotspot/src/share/vm/jvmci/jvmciRuntime.hpp | 25 --------------------- 1 file changed, 25 deletions(-) diff --git a/hotspot/src/share/vm/jvmci/jvmciRuntime.hpp b/hotspot/src/share/vm/jvmci/jvmciRuntime.hpp index ebd5d3c72b6..bf7b59e1566 100644 --- a/hotspot/src/share/vm/jvmci/jvmciRuntime.hpp +++ b/hotspot/src/share/vm/jvmci/jvmciRuntime.hpp @@ -40,31 +40,6 @@ #define JVMCI_ERROR_OK(...) JVMCI_ERROR_(JVMCIEnv::ok, __VA_ARGS__) #define CHECK_OK CHECK_(JVMCIEnv::ok) -class ParseClosure : public StackObj { - int _lineNo; - char* _filename; - bool _abort; -protected: - void abort() { _abort = true; } - void warn_and_abort(const char* message) { - warn(message); - abort(); - } - void warn(const char* message) { - warning("Error at line %d while parsing %s: %s", _lineNo, _filename == NULL ? "?" : _filename, message); - } - public: - ParseClosure() : _lineNo(0), _filename(NULL), _abort(false) {} - void parse_line(char* line) { - _lineNo++; - do_line(line); - } - virtual void do_line(char* line) = 0; - int lineNo() { return _lineNo; } - bool is_aborted() { return _abort; } - void set_filename(char* path) {_filename = path; _lineNo = 0;} -}; - class JVMCIRuntime: public AllStatic { public: // Constants describing whether JVMCI wants to be able to adjust the compilation From c82212e143e93dd52300776a869793243a21d4e6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Markus=20Gr=C3=B6nlund?= Date: Mon, 6 Jun 2016 20:48:56 +0200 Subject: [PATCH 023/125] 8149803: Adjust lock rankings for some Event-based tracing locks Reviewed-by: dholmes, acorn --- hotspot/src/share/vm/runtime/mutexLocker.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/runtime/mutexLocker.cpp b/hotspot/src/share/vm/runtime/mutexLocker.cpp index 219194a4b21..a01b4888500 100644 --- a/hotspot/src/share/vm/runtime/mutexLocker.cpp +++ b/hotspot/src/share/vm/runtime/mutexLocker.cpp @@ -274,7 +274,7 @@ void mutex_init() { def(JfrMsg_lock , Monitor, leaf, true, Monitor::_safepoint_check_always); def(JfrBuffer_lock , Mutex, leaf, true, Monitor::_safepoint_check_never); def(JfrThreadGroups_lock , Mutex, leaf, true, Monitor::_safepoint_check_always); - def(JfrStream_lock , Mutex, nonleaf, true, Monitor::_safepoint_check_never); + def(JfrStream_lock , Mutex, leaf+1, true, Monitor::_safepoint_check_never); // ensure to rank lower than 'safepoint' def(JfrStacktrace_lock , Mutex, special, true, Monitor::_safepoint_check_sometimes); #endif From 2137769825992a15cc0a5896220aadd0f620bd15 Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Mon, 6 Jun 2016 22:34:57 +0300 Subject: [PATCH 024/125] 8075030: JvmtiEnv::GetObjectSize reports incorrect java.lang.Class instance size Reviewed-by: coleenp, sspitsyn, sla --- hotspot/src/share/vm/prims/jvmtiEnv.cpp | 10 +--- .../jvmti/GetObjectSizeClass.java | 55 +++++++++++++++++++ .../jvmti/GetObjectSizeClassAgent.java | 51 +++++++++++++++++ 3 files changed, 107 insertions(+), 9 deletions(-) create mode 100644 hotspot/test/serviceability/jvmti/GetObjectSizeClass.java create mode 100644 hotspot/test/serviceability/jvmti/GetObjectSizeClassAgent.java diff --git a/hotspot/src/share/vm/prims/jvmtiEnv.cpp b/hotspot/src/share/vm/prims/jvmtiEnv.cpp index d6f60a28f77..082d531daf1 100644 --- a/hotspot/src/share/vm/prims/jvmtiEnv.cpp +++ b/hotspot/src/share/vm/prims/jvmtiEnv.cpp @@ -319,15 +319,7 @@ jvmtiError JvmtiEnv::GetObjectSize(jobject object, jlong* size_ptr) { oop mirror = JNIHandles::resolve_external_guard(object); NULL_CHECK(mirror, JVMTI_ERROR_INVALID_OBJECT); - - if (mirror->klass() == SystemDictionary::Class_klass() && - !java_lang_Class::is_primitive(mirror)) { - Klass* k = java_lang_Class::as_Klass(mirror); - assert(k != NULL, "class for non-primitive mirror must exist"); - *size_ptr = (jlong)k->size() * wordSize; - } else { - *size_ptr = (jlong)mirror->size() * wordSize; - } + *size_ptr = (jlong)mirror->size() * wordSize; return JVMTI_ERROR_NONE; } /* end GetObjectSize */ diff --git a/hotspot/test/serviceability/jvmti/GetObjectSizeClass.java b/hotspot/test/serviceability/jvmti/GetObjectSizeClass.java new file mode 100644 index 00000000000..cec03f32947 --- /dev/null +++ b/hotspot/test/serviceability/jvmti/GetObjectSizeClass.java @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +import java.io.PrintWriter; +import jdk.test.lib.*; + +/* + * @test + * @bug 8075030 + * @summary JvmtiEnv::GetObjectSize reports incorrect java.lang.Class instance size + * @library /testlibrary + * @modules java.base/jdk.internal.misc + * java.compiler + * java.instrument + * java.management + * jdk.jvmstat/sun.jvmstat.monitor + * @build ClassFileInstaller jdk.test.lib.* GetObjectSizeClassAgent + * @run main ClassFileInstaller GetObjectSizeClassAgent + * @run main GetObjectSizeClass + */ +public class GetObjectSizeClass { + public static void main(String[] args) throws Exception { + PrintWriter pw = new PrintWriter("MANIFEST.MF"); + pw.println("Premain-Class: GetObjectSizeClassAgent"); + pw.close(); + + ProcessBuilder pb = new ProcessBuilder(); + pb.command(new String[] { JDKToolFinder.getJDKTool("jar"), "cmf", "MANIFEST.MF", "agent.jar", "GetObjectSizeClassAgent.class"}); + pb.start().waitFor(); + + ProcessBuilder pt = ProcessTools.createJavaProcessBuilder(true, "-javaagent:agent.jar", "GetObjectSizeClassAgent"); + OutputAnalyzer output = new OutputAnalyzer(pt.start()); + + output.stdoutShouldContain("GetObjectSizeClass passed"); + } +} diff --git a/hotspot/test/serviceability/jvmti/GetObjectSizeClassAgent.java b/hotspot/test/serviceability/jvmti/GetObjectSizeClassAgent.java new file mode 100644 index 00000000000..0b5cac4f07d --- /dev/null +++ b/hotspot/test/serviceability/jvmti/GetObjectSizeClassAgent.java @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +import java.lang.instrument.*; + +public class GetObjectSizeClassAgent { + + static Instrumentation instrumentation; + + public static void premain(String agentArgs, Instrumentation instrumentation) { + GetObjectSizeClassAgent.instrumentation = instrumentation; + } + + public static void main(String[] args) throws Exception { + long sizeA = instrumentation.getObjectSize(A.class); + long sizeB = instrumentation.getObjectSize(B.class); + + if (sizeA != sizeB) { + throw new RuntimeException("java.lang.Class sizes disagree: " + sizeA + " vs. " + sizeB); + } + + System.out.println("GetObjectSizeClass passed"); + } + + static class A { + } + + static class B { + void m() {} + } + +} From 66e3ba7296cfe4dd26f69873cff8df7efd2e3c46 Mon Sep 17 00:00:00 2001 From: Calvin Cheung Date: Mon, 6 Jun 2016 12:51:53 -0700 Subject: [PATCH 025/125] 8153876: Replace 4K stack allocations with Resource allocations Reviewed-by: dholmes, hseigel --- .../src/share/vm/classfile/classLoader.cpp | 25 +++++++++++-------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/hotspot/src/share/vm/classfile/classLoader.cpp b/hotspot/src/share/vm/classfile/classLoader.cpp index 12858cccf28..acc65eb9a8a 100644 --- a/hotspot/src/share/vm/classfile/classLoader.cpp +++ b/hotspot/src/share/vm/classfile/classLoader.cpp @@ -228,8 +228,9 @@ ClassPathDirEntry::ClassPathDirEntry(const char* dir) : ClassPathEntry() { ClassFileStream* ClassPathDirEntry::open_stream(const char* name, TRAPS) { // construct full path name - char path[JVM_MAXPATHLEN]; - if (jio_snprintf(path, sizeof(path), "%s%s%s", _dir, os::file_separator(), name) == -1) { + char* path = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, JVM_MAXPATHLEN); + if (jio_snprintf(path, JVM_MAXPATHLEN, "%s%s%s", _dir, os::file_separator(), name) == -1) { + FREE_RESOURCE_ARRAY(char, path, JVM_MAXPATHLEN); return NULL; } // check if file exists @@ -256,6 +257,7 @@ ClassFileStream* ClassPathDirEntry::open_stream(const char* name, TRAPS) { if (UsePerfData) { ClassLoader::perf_sys_classfile_bytes_read()->inc(num_read); } + FREE_RESOURCE_ARRAY(char, path, JVM_MAXPATHLEN); // Resource allocated return new ClassFileStream(buffer, st.st_size, @@ -264,6 +266,7 @@ ClassFileStream* ClassPathDirEntry::open_stream(const char* name, TRAPS) { } } } + FREE_RESOURCE_ARRAY(char, path, JVM_MAXPATHLEN); return NULL; } @@ -344,9 +347,10 @@ u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TR if (is_multi_ver) { int n; - char entry_name[JVM_MAXPATHLEN]; + ResourceMark rm(THREAD); + char* entry_name = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, JVM_MAXPATHLEN); if (version > 0) { - n = jio_snprintf(entry_name, sizeof(entry_name), "META-INF/versions/%d/%s", version, name); + n = jio_snprintf(entry_name, JVM_MAXPATHLEN, "META-INF/versions/%d/%s", version, name); entry_name[n] = '\0'; buffer = open_entry((const char*)entry_name, filesize, false, CHECK_NULL); if (buffer == NULL) { @@ -355,7 +359,7 @@ u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TR } if (buffer == NULL) { for (int i = cur_ver; i >= base_version; i--) { - n = jio_snprintf(entry_name, sizeof(entry_name), "META-INF/versions/%d/%s", i, name); + n = jio_snprintf(entry_name, JVM_MAXPATHLEN, "META-INF/versions/%d/%s", i, name); entry_name[n] = '\0'; buffer = open_entry((const char*)entry_name, filesize, false, CHECK_NULL); if (buffer != NULL) { @@ -508,7 +512,8 @@ bool ctw_visitor(JImageFile* jimage, const char* name, const char* extension, void* arg) { if (strcmp(extension, "class") == 0) { Thread* THREAD = Thread::current(); - char path[JIMAGE_MAX_PATH]; + ResourceMark rm(THREAD); + char* path = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, JIMAGE_MAX_PATH); jio_snprintf(path, JIMAGE_MAX_PATH - 1, "%s/%s.class", package, name); ClassLoader::compile_the_world_in(path, *(Handle*)arg, THREAD); return !HAS_PENDING_EXCEPTION; @@ -750,9 +755,10 @@ ClassPathEntry* ClassLoader::create_class_path_entry(const char *path, const str JavaThread* thread = JavaThread::current(); ClassPathEntry* new_entry = NULL; if ((st->st_mode & S_IFREG) == S_IFREG) { + ResourceMark rm(thread); // Regular file, should be a zip or jimage file // Canonicalized filename - char canonical_path[JVM_MAXPATHLEN]; + char* canonical_path = NEW_RESOURCE_ARRAY_IN_THREAD(thread, char, JVM_MAXPATHLEN); if (!get_canonical_path(path, canonical_path, JVM_MAXPATHLEN)) { // This matches the classic VM if (throw_exception) { @@ -777,14 +783,13 @@ ClassPathEntry* ClassLoader::create_class_path_entry(const char *path, const str if (zip != NULL && error_msg == NULL) { new_entry = new ClassPathZipEntry(zip, path, is_boot_append); } else { - ResourceMark rm(thread); char *msg; if (error_msg == NULL) { - msg = NEW_RESOURCE_ARRAY(char, strlen(path) + 128); ; + msg = NEW_RESOURCE_ARRAY_IN_THREAD(thread, char, strlen(path) + 128); ; jio_snprintf(msg, strlen(path) + 127, "error in opening JAR file %s", path); } else { int len = (int)(strlen(path) + strlen(error_msg) + 128); - msg = NEW_RESOURCE_ARRAY(char, len); ; + msg = NEW_RESOURCE_ARRAY_IN_THREAD(thread, char, len); ; jio_snprintf(msg, len - 1, "error in opening JAR file <%s> %s", error_msg, path); } // Don't complain about bad jar files added via -Xbootclasspath/a:. From 39e5b15fdd20d08b49f929bb44f361cb1b45d7ee Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Mon, 6 Jun 2016 16:31:03 -0700 Subject: [PATCH 026/125] 8156587: [JVMCI] remove Unsafe.getJavaMirror and Unsafe.getKlassPointer Reviewed-by: kvn --- hotspot/src/share/vm/prims/unsafe.cpp | 15 ------ .../compilerToVM/GetConstantPoolTest.java | 11 ----- .../compilerToVM/GetResolvedJavaTypeTest.java | 14 +----- .../Unsafe/GetKlassPointerGetJavaMirror.java | 47 ------------------- 4 files changed, 1 insertion(+), 86 deletions(-) delete mode 100644 hotspot/test/runtime/Unsafe/GetKlassPointerGetJavaMirror.java diff --git a/hotspot/src/share/vm/prims/unsafe.cpp b/hotspot/src/share/vm/prims/unsafe.cpp index 71116760c07..e129fbafc41 100644 --- a/hotspot/src/share/vm/prims/unsafe.cpp +++ b/hotspot/src/share/vm/prims/unsafe.cpp @@ -356,19 +356,6 @@ UNSAFE_ENTRY(jobject, Unsafe_GetUncompressedObject(JNIEnv *env, jobject unsafe, return JNIHandles::make_local(env, v); } UNSAFE_END -UNSAFE_ENTRY(jclass, Unsafe_GetJavaMirror(JNIEnv *env, jobject unsafe, jlong metaspace_klass)) { - Klass* klass = (Klass*) (address) metaspace_klass; - - return (jclass) JNIHandles::make_local(klass->java_mirror()); -} UNSAFE_END - -UNSAFE_ENTRY(jlong, Unsafe_GetKlassPointer(JNIEnv *env, jobject unsafe, jobject obj)) { - oop o = JNIHandles::resolve(obj); - jlong klass = (jlong) (address) o->klass(); - - return klass; -} UNSAFE_END - #ifndef SUPPORTS_NATIVE_CX8 // VM_Version::supports_cx8() is a surrogate for 'supports atomic long memory ops'. @@ -1152,8 +1139,6 @@ static JNINativeMethod jdk_internal_misc_Unsafe_methods[] = { {CC "putObjectVolatile",CC "(" OBJ "J" OBJ ")V", FN_PTR(Unsafe_PutObjectVolatile)}, {CC "getUncompressedObject", CC "(" ADR ")" OBJ, FN_PTR(Unsafe_GetUncompressedObject)}, - {CC "getJavaMirror", CC "(" ADR ")" CLS, FN_PTR(Unsafe_GetJavaMirror)}, - {CC "getKlassPointer", CC "(" OBJ ")" ADR, FN_PTR(Unsafe_GetKlassPointer)}, DECLARE_GETPUTOOP(Boolean, Z), DECLARE_GETPUTOOP(Byte, B), diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java index 28463d71e75..c9826c857e3 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java @@ -138,17 +138,6 @@ public class GetConstantPoolTest { return CompilerToVMHelper.getConstantPool(cpInst, ptr); } }, - OBJECT_TYPE_BASE { - @Override - ConstantPool getConstantPool() { - HotSpotResolvedObjectType type - = HotSpotResolvedObjectType.fromObjectClass( - OBJECT_TYPE_BASE.getClass()); - long ptrToClass = UNSAFE.getKlassPointer(OBJECT_TYPE_BASE); - return CompilerToVMHelper.getConstantPool(type, - getPtrToCpAddress() - ptrToClass); - } - }, ; abstract ConstantPool getConstantPool(); } diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java index 1dde0850aad..a648caaac67 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java @@ -24,6 +24,7 @@ /* * @test * @bug 8136421 + * @ignore 8158860 * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches @@ -149,25 +150,12 @@ public class GetResolvedJavaTypeTest { ptr, COMPRESSED); } }, - OBJECT_TYPE_BASE { - @Override - HotSpotResolvedObjectType getResolvedJavaType() { - HotSpotResolvedObjectType type - = HotSpotResolvedObjectType.fromObjectClass( - OBJECT_TYPE_BASE.getClass()); - long ptrToClass = UNSAFE.getKlassPointer(OBJECT_TYPE_BASE); - return CompilerToVMHelper.getResolvedJavaType(type, - getPtrToKlass() - ptrToClass, COMPRESSED); - } - }, ; abstract HotSpotResolvedObjectType getResolvedJavaType(); } private static final Unsafe UNSAFE = Utils.getUnsafe(); private static final WhiteBox WB = WhiteBox.getWhiteBox(); - private static final long PTR = UNSAFE.getKlassPointer( - new GetResolvedJavaTypeTest()); private static final Class TEST_CLASS = GetResolvedJavaTypeTest.class; /* a compressed parameter for tested method is set to false because unsafe.getKlassPointer always returns uncompressed pointer */ diff --git a/hotspot/test/runtime/Unsafe/GetKlassPointerGetJavaMirror.java b/hotspot/test/runtime/Unsafe/GetKlassPointerGetJavaMirror.java deleted file mode 100644 index 7a53be5e7e5..00000000000 --- a/hotspot/test/runtime/Unsafe/GetKlassPointerGetJavaMirror.java +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 8022853 - * @library /testlibrary - * @modules java.base/jdk.internal.misc - * @build jdk.test.lib.* - * @run main GetKlassPointerGetJavaMirror - */ - -import static jdk.test.lib.Asserts.*; - -import jdk.test.lib.*; -import jdk.internal.misc.Unsafe; - -public class GetKlassPointerGetJavaMirror { - - public static void main(String args[]) throws Exception { - Unsafe unsafe = Utils.getUnsafe(); - Object o = new GetKlassPointerGetJavaMirror(); - final long metaspaceKlass = unsafe.getKlassPointer(o); - Class c = unsafe.getJavaMirror(metaspaceKlass); - assertEquals(o.getClass(), c); - } - -} From 9ead05c2dc2fdeaf47d2e86d8cc2523ff5ec8ce7 Mon Sep 17 00:00:00 2001 From: Jamsheed Mohammed C M Date: Mon, 6 Jun 2016 23:24:46 -0700 Subject: [PATCH 027/125] 8146416: java.lang.OutOfMemoryError triggers: assert(current_bci == 0) failed: bci isn't zero for do_not_unlock_if_synchronized Handle realloc failure pending exception. Reviewed-by: roland --- .../src/share/vm/runtime/deoptimization.cpp | 13 +++ hotspot/src/share/vm/runtime/vframeArray.cpp | 13 ++- .../uncommontrap/DeoptReallocFailure.java | 91 +++++++++++++++++++ 3 files changed, 115 insertions(+), 2 deletions(-) create mode 100644 hotspot/test/compiler/uncommontrap/DeoptReallocFailure.java diff --git a/hotspot/src/share/vm/runtime/deoptimization.cpp b/hotspot/src/share/vm/runtime/deoptimization.cpp index f926b88eca8..aca59f7ef83 100644 --- a/hotspot/src/share/vm/runtime/deoptimization.cpp +++ b/hotspot/src/share/vm/runtime/deoptimization.cpp @@ -498,6 +498,19 @@ Deoptimization::UnrollBlock* Deoptimization::fetch_unroll_info_helper(JavaThread } #endif + if (thread->frames_to_pop_failed_realloc() > 0 && exec_mode != Unpack_uncommon_trap) { + assert(thread->has_pending_exception(), "should have thrown OOME"); + thread->set_exception_oop(thread->pending_exception()); + thread->clear_pending_exception(); + exec_mode = Unpack_exception; + } + +#if INCLUDE_JVMCI + if (thread->frames_to_pop_failed_realloc() > 0) { + thread->set_pending_monitorenter(false); + } +#endif + UnrollBlock* info = new UnrollBlock(array->frame_size() * BytesPerWord, caller_adjustment * BytesPerWord, caller_was_method_handle ? 0 : callee_parameters, diff --git a/hotspot/src/share/vm/runtime/vframeArray.cpp b/hotspot/src/share/vm/runtime/vframeArray.cpp index 483473244eb..abfb5afde82 100644 --- a/hotspot/src/share/vm/runtime/vframeArray.cpp +++ b/hotspot/src/share/vm/runtime/vframeArray.cpp @@ -171,6 +171,8 @@ void vframeArrayElement::unpack_on_stack(int caller_actual_parameters, int exec_mode) { JavaThread* thread = (JavaThread*) Thread::current(); + bool realloc_failure_exception = thread->frames_to_pop_failed_realloc() > 0; + // Look at bci and decide on bcp and continuation pc address bcp; // C++ interpreter doesn't need a pc since it will figure out what to do when it @@ -204,10 +206,12 @@ void vframeArrayElement::unpack_on_stack(int caller_actual_parameters, // // For Compiler1, deoptimization can occur while throwing a NullPointerException at monitorenter, // in which case bcp should point to the monitorenter since it is within the exception's range. + // + // For realloc failure exception we just pop frames, skip the guarantee. assert(*bcp != Bytecodes::_monitorenter || is_top_frame, "a _monitorenter must be a top frame"); assert(thread->deopt_compiled_method() != NULL, "compiled method should be known"); - guarantee(!(thread->deopt_compiled_method()->is_compiled_by_c2() && + guarantee(realloc_failure_exception || !(thread->deopt_compiled_method()->is_compiled_by_c2() && *bcp == Bytecodes::_monitorenter && exec_mode == Deoptimization::Unpack_exception), "shouldn't get exception during monitorenter"); @@ -237,12 +241,17 @@ void vframeArrayElement::unpack_on_stack(int caller_actual_parameters, // Deoptimization::fetch_unroll_info_helper popframe_preserved_args_size_in_words = in_words(thread->popframe_preserved_args_size_in_words()); } - } else if (JvmtiExport::can_force_early_return() && state != NULL && state->is_earlyret_pending()) { + } else if (!realloc_failure_exception && JvmtiExport::can_force_early_return() && state != NULL && state->is_earlyret_pending()) { // Force early return from top frame after deoptimization #ifndef CC_INTERP pc = Interpreter::remove_activation_early_entry(state->earlyret_tos()); #endif } else { + if (realloc_failure_exception && JvmtiExport::can_force_early_return() && state != NULL && state->is_earlyret_pending()) { + state->clr_earlyret_pending(); + state->set_earlyret_oop(NULL); + state->clr_earlyret_value(); + } // Possibly override the previous pc computation of the top (youngest) frame switch (exec_mode) { case Deoptimization::Unpack_deopt: diff --git a/hotspot/test/compiler/uncommontrap/DeoptReallocFailure.java b/hotspot/test/compiler/uncommontrap/DeoptReallocFailure.java new file mode 100644 index 00000000000..1064527b9da --- /dev/null +++ b/hotspot/test/compiler/uncommontrap/DeoptReallocFailure.java @@ -0,0 +1,91 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8146416 + * @library /test/lib /testlibrary / + * @build sun.hotspot.WhiteBox + * @run main ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbatch -XX:CompileCommand=exclude,DeoptReallocFailure::main -Xmx100m DeoptReallocFailure + * + */ +import java.lang.reflect.Method; +import sun.hotspot.WhiteBox; + +class MemoryChunk { + MemoryChunk other; + Object[][] array; + + MemoryChunk(MemoryChunk other) { + this.other = other; + array = new Object[1024 * 256][]; + } +} + +class NoEscape { + long f1; +} + +public class DeoptReallocFailure { + + static MemoryChunk root; + private static final WhiteBox WB = WhiteBox.getWhiteBox(); + + public static synchronized long test() { + NoEscape[] noEscape = new NoEscape[45]; + noEscape[0] = new NoEscape(); + for (int i=0;i<1024*256;i++) { + root.array[i]= new Object[45]; + } + return noEscape[0].f1; + } + + public static void main(String[] args) throws Throwable { + + //Exhaust Memory + root = null; + try { + while (true) { + root = new MemoryChunk(root); + } + } catch (OutOfMemoryError oom) { + } + + if (root == null) { + return; + } + + try { + NoEscape dummy = new NoEscape(); + Method m = DeoptReallocFailure.class.getMethod("test"); + WB.enqueueMethodForCompilation(m, 4); + test(); + } catch (OutOfMemoryError oom) { + root = null; + oom.printStackTrace(); + } + System.out.println("TEST PASSED"); + } +} From f35b70764b31077f257b0ac2bccef40d1cdc497a Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Tue, 7 Jun 2016 12:55:29 +0300 Subject: [PATCH 028/125] 8154209: Remove client VM from default JIB profile on windows-x86 and linux-x86 Reviewed-by: dholmes --- hotspot/test/runtime/SharedArchiveFile/DefaultUseWithClient.java | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/test/runtime/SharedArchiveFile/DefaultUseWithClient.java b/hotspot/test/runtime/SharedArchiveFile/DefaultUseWithClient.java index 050b0ff6f27..2fe4753bdbc 100644 --- a/hotspot/test/runtime/SharedArchiveFile/DefaultUseWithClient.java +++ b/hotspot/test/runtime/SharedArchiveFile/DefaultUseWithClient.java @@ -27,6 +27,7 @@ * @library /testlibrary * @modules java.base/jdk.internal.misc * java.management + * @ignore 8154204 * @run main DefaultUseWithClient * @bug 8032224 */ From e45caa8cbaa7888969d53d0213cf743dcc60c485 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Tue, 7 Jun 2016 18:20:44 +0200 Subject: [PATCH 029/125] 8158228: C1 incorrectly folds mismatched loads from stable arrays Disable constant folding for mismatched loads from stable arrays. Reviewed-by: vlivanov --- hotspot/src/share/vm/c1/c1_Canonicalizer.cpp | 6 +-- hotspot/src/share/vm/c1/c1_GraphBuilder.cpp | 4 +- hotspot/src/share/vm/c1/c1_Instruction.hpp | 14 ++++-- .../compiler/stable/TestStableMismatched.java | 50 +++++++++++++++++++ 4 files changed, 63 insertions(+), 11 deletions(-) create mode 100644 hotspot/test/compiler/stable/TestStableMismatched.java diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp index 7e65f3c235f..e3a7af67742 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -264,7 +264,7 @@ void Canonicalizer::do_LoadIndexed (LoadIndexed* x) { assert(array == NULL || FoldStableValues, "not enabled"); // Constant fold loads from stable arrays. - if (array != NULL && index != NULL) { + if (!x->mismatched() && array != NULL && index != NULL) { jint idx = index->value(); if (idx < 0 || idx >= array->value()->length()) { // Leave the load as is. The range check will handle it. @@ -310,8 +310,6 @@ void Canonicalizer::do_StoreIndexed (StoreIndexed* x) { return; } } - - } diff --git a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp index 69d475ac939..0c06df4751c 100644 --- a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp +++ b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp @@ -4227,11 +4227,11 @@ void GraphBuilder::append_char_access(ciMethod* callee, bool is_store) { Value index = args->at(1); if (is_store) { Value value = args->at(2); - Instruction* store = append(new StoreIndexed(array, index, NULL, T_CHAR, value, state_before, false)); + Instruction* store = append(new StoreIndexed(array, index, NULL, T_CHAR, value, state_before, false, true)); store->set_flag(Instruction::NeedsRangeCheckFlag, false); _memory->store_value(value); } else { - Instruction* load = append(new LoadIndexed(array, index, NULL, T_CHAR, state_before)); + Instruction* load = append(new LoadIndexed(array, index, NULL, T_CHAR, state_before, true)); load->set_flag(Instruction::NeedsRangeCheckFlag, false); push(load->type(), load); } diff --git a/hotspot/src/share/vm/c1/c1_Instruction.hpp b/hotspot/src/share/vm/c1/c1_Instruction.hpp index 426507d301a..4b01069498c 100644 --- a/hotspot/src/share/vm/c1/c1_Instruction.hpp +++ b/hotspot/src/share/vm/c1/c1_Instruction.hpp @@ -912,14 +912,16 @@ BASE(AccessIndexed, AccessArray) Value _index; Value _length; BasicType _elt_type; + bool _mismatched; public: // creation - AccessIndexed(Value array, Value index, Value length, BasicType elt_type, ValueStack* state_before) + AccessIndexed(Value array, Value index, Value length, BasicType elt_type, ValueStack* state_before, bool mismatched) : AccessArray(as_ValueType(elt_type), array, state_before) , _index(index) , _length(length) , _elt_type(elt_type) + , _mismatched(mismatched) { set_flag(Instruction::NeedsRangeCheckFlag, true); ASSERT_VALUES @@ -929,6 +931,7 @@ BASE(AccessIndexed, AccessArray) Value index() const { return _index; } Value length() const { return _length; } BasicType elt_type() const { return _elt_type; } + bool mismatched() const { return _mismatched; } void clear_length() { _length = NULL; } // perform elimination of range checks involving constants @@ -945,8 +948,8 @@ LEAF(LoadIndexed, AccessIndexed) public: // creation - LoadIndexed(Value array, Value index, Value length, BasicType elt_type, ValueStack* state_before) - : AccessIndexed(array, index, length, elt_type, state_before) + LoadIndexed(Value array, Value index, Value length, BasicType elt_type, ValueStack* state_before, bool mismatched = false) + : AccessIndexed(array, index, length, elt_type, state_before, mismatched) , _explicit_null_check(NULL) {} // accessors @@ -974,8 +977,9 @@ LEAF(StoreIndexed, AccessIndexed) public: // creation - StoreIndexed(Value array, Value index, Value length, BasicType elt_type, Value value, ValueStack* state_before, bool check_boolean) - : AccessIndexed(array, index, length, elt_type, state_before) + StoreIndexed(Value array, Value index, Value length, BasicType elt_type, Value value, ValueStack* state_before, + bool check_boolean, bool mismatched = false) + : AccessIndexed(array, index, length, elt_type, state_before, mismatched) , _value(value), _profiled_method(NULL), _profiled_bci(0), _check_boolean(check_boolean) { set_flag(NeedsWriteBarrierFlag, (as_ValueType(elt_type)->is_object())); diff --git a/hotspot/test/compiler/stable/TestStableMismatched.java b/hotspot/test/compiler/stable/TestStableMismatched.java new file mode 100644 index 00000000000..a71ee78aa66 --- /dev/null +++ b/hotspot/test/compiler/stable/TestStableMismatched.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +/* + * @test TestStableMismatched + * @bug 8158228 + * @summary Tests if mismatched char load from stable byte[] returns correct result + * @run main/othervm -XX:-CompactStrings -XX:TieredStopAtLevel=1 -Xcomp + * -XX:CompileOnly=TestStableMismatched::test,::charAt + * TestStableMismatched + * @run main/othervm -XX:-CompactStrings -XX:-TieredCompilation -Xcomp + * -XX:CompileOnly=TestStableMismatched::test,::charAt + * TestStableMismatched + */ +public class TestStableMismatched { + public static void main(String args[]) { + test(); + } + + public static void test() { + String text = "abcdefg"; + // Mismatched char load from @Stable byte[] String.value field + char returned = text.charAt(6); + if (returned != 'g') { + throw new RuntimeException("failed: charAt(6) returned '" + returned + "' instead of 'g'"); + } + } +} + From dafa4695a0e34c461a2024a498627afe2652f3b8 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Tue, 7 Jun 2016 17:16:51 -0700 Subject: [PATCH 030/125] 8158985: [JVMCI] access to HotSpotJVMCIRuntime.vmEventListeners must be thread safe Reviewed-by: iveresov, kvn --- .../vm/ci/hotspot/HotSpotJVMCIRuntime.java | 28 +++++++++++++++---- 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java index 5cf038e0bf8..c8b12aefe32 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java @@ -31,10 +31,13 @@ import java.lang.reflect.Array; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.lang.reflect.Modifier; +import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; +import java.util.List; import java.util.Map; import java.util.Objects; +import java.util.ServiceLoader; import java.util.TreeMap; import jdk.internal.misc.VM; @@ -213,7 +216,22 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { private final Map, JVMCIBackend> backends = new HashMap<>(); - private final Iterable vmEventListeners; + private volatile List vmEventListeners; + + private Iterable getVmEventListeners() { + if (vmEventListeners == null) { + synchronized (this) { + if (vmEventListeners == null) { + List listeners = new ArrayList<>(); + for (HotSpotVMEventListener vmEventListener : ServiceLoader.load(HotSpotVMEventListener.class)) { + listeners.add(vmEventListener); + } + vmEventListeners = listeners; + } + } + } + return vmEventListeners; + } /** * Stores the result of {@link HotSpotJVMCICompilerFactory#getTrivialPrefixes()} so that it can @@ -240,8 +258,6 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { hostBackend = registerBackend(factory.createJVMCIBackend(this, null)); } - vmEventListeners = Services.load(HotSpotVMEventListener.class); - metaAccessContext = new HotSpotJVMCIMetaAccessContext(); boolean printFlags = Option.PrintFlags.getBoolean(); @@ -370,7 +386,7 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { */ @SuppressWarnings({"unused"}) private void shutdown() throws Exception { - for (HotSpotVMEventListener vmEventListener : vmEventListeners) { + for (HotSpotVMEventListener vmEventListener : getVmEventListeners()) { vmEventListener.notifyShutdown(); } } @@ -382,7 +398,7 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { */ @SuppressWarnings({"unused"}) private void bootstrapFinished() throws Exception { - for (HotSpotVMEventListener vmEventListener : vmEventListeners) { + for (HotSpotVMEventListener vmEventListener : getVmEventListeners()) { vmEventListener.notifyBootstrapFinished(); } } @@ -395,7 +411,7 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { * @param compiledCode */ void notifyInstall(HotSpotCodeCacheProvider hotSpotCodeCacheProvider, InstalledCode installedCode, CompiledCode compiledCode) { - for (HotSpotVMEventListener vmEventListener : vmEventListeners) { + for (HotSpotVMEventListener vmEventListener : getVmEventListeners()) { vmEventListener.notifyInstall(hotSpotCodeCacheProvider, installedCode, compiledCode); } } From 067e915c50e30997297854914cd013f2458a0417 Mon Sep 17 00:00:00 2001 From: Felix Yang Date: Tue, 7 Jun 2016 10:17:28 +0000 Subject: [PATCH 031/125] 8158913: aarch64: SEGV running Spark terasort Use signed instead of unsigned test for end of loop in gen_write_ref_array_post_barrier Reviewed-by: aph --- hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp index 075bf794650..b93e9b19bdd 100644 --- a/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/stubGenerator_aarch64.cpp @@ -710,7 +710,7 @@ class StubGenerator: public StubCodeGenerator { __ BIND(L_loop); __ strb(zr, Address(start, count)); __ subs(count, count, 1); - __ br(Assembler::HS, L_loop); + __ br(Assembler::GE, L_loop); } break; default: From 7bd006dd5a608ae891f199a1e7fb588a8bdb1b56 Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Tue, 7 Jun 2016 16:08:25 +0200 Subject: [PATCH 032/125] 8158929: [TESTBUG] CommitOverlappingRegions.java can not deal with pages > 32K Reviewed-by: mockner, dholmes --- .../runtime/NMT/CommitOverlappingRegions.java | 55 ++++++++++--------- 1 file changed, 30 insertions(+), 25 deletions(-) diff --git a/hotspot/test/runtime/NMT/CommitOverlappingRegions.java b/hotspot/test/runtime/NMT/CommitOverlappingRegions.java index 212a9930fd3..773378ce7e8 100644 --- a/hotspot/test/runtime/NMT/CommitOverlappingRegions.java +++ b/hotspot/test/runtime/NMT/CommitOverlappingRegions.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,7 +41,12 @@ public class CommitOverlappingRegions { public static WhiteBox wb = WhiteBox.getWhiteBox(); public static void main(String args[]) throws Exception { OutputAnalyzer output; + long size = 32 * 1024; + int pagesize = wb.getVMPageSize(); + if (size < pagesize) { size = pagesize; } // Should be aligned. + long sizek = size / 1024; + long addr = wb.NMTReserveMemory(8*size); String pid = Long.toString(ProcessTools.getProcessId()); @@ -52,93 +57,93 @@ public class CommitOverlappingRegions { // Start: . . . . . . . . output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=0KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=0KB)"); // Committing: * * * . . . . . // Region: * * * . . . . . - // Expected Total: 3 x 32KB = 96KB + // Expected Total: 3 x sizek KB wb.NMTCommitMemory(addr + 0*size, 3*size); // Committing: . . . . * * * . // Region: * * * . * * * . - // Expected Total: 6 x 32KB = 192KB + // Expected Total: 6 x sizek KB wb.NMTCommitMemory(addr + 4*size, 3*size); // Check output after first 2 commits. output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=192KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 6*sizek + "KB)"); // Committing: . . * * * . . . // Region: * * * * * * * . - // Expected Total: 7 x 32KB = 224KB + // Expected Total: 7 x sizek KB wb.NMTCommitMemory(addr + 2*size, 3*size); // Check output after overlapping commit. output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=224KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 7*sizek + "KB)"); // Uncommitting: * * * * * * * * // Region: . . . . . . . . - // Expected Total: 0 x 32KB = 0KB + // Expected Total: 0 x sizek KB wb.NMTUncommitMemory(addr + 0*size, 8*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=0KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=0KB)"); // Committing: * * . . . . . . // Region: * * . . . . . . - // Expected Total: 2 x 32KB = 64KB + // Expected Total: 2 x sizek KB wb.NMTCommitMemory(addr + 0*size, 2*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=64KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 2*sizek + "KB)"); // Committing: . * * * . . . . // Region: * * * * . . . . - // Expected Total: 4 x 32KB = 128KB + // Expected Total: 4 x sizek KB wb.NMTCommitMemory(addr + 1*size, 3*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=128KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 4*sizek + "KB)"); // Uncommitting: * * * . . . . . // Region: . . . * . . . . - // Expected Total: 1 x 32KB = 32KB + // Expected Total: 1 x sizek KB wb.NMTUncommitMemory(addr + 0*size, 3*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=32KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 1*sizek + "KB)"); // Committing: . . . * * . . . // Region: . . . * * . . . - // Expected Total: 2 x 32KB = 64KB + // Expected Total: 2 x sizek KB wb.NMTCommitMemory(addr + 3*size, 2*size); System.out.println("Address is " + Long.toHexString(addr + 3*size)); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=64KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 2*sizek + "KB)"); // Committing: . . . . * * . . // Region: . . . * * * . . - // Expected Total: 3 x 32KB = 96KB + // Expected Total: 3 x sizek KB wb.NMTCommitMemory(addr + 4*size, 2*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=96KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 3*sizek + "KB)"); // Committing: . . . . . * * . // Region: . . . * * * * . - // Expected Total: 4 x 32KB = 128KB + // Expected Total: 4 x sizek KB wb.NMTCommitMemory(addr + 5*size, 2*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=128KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 4*sizek + "KB)"); // Committing: . . . . . . * * // Region: . . . * * * * * - // Expected Total: 5 x 32KB = 160KB + // Expected Total: 5 x sizek KB wb.NMTCommitMemory(addr + 6*size, 2*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=160KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=" + 5*sizek + "KB)"); // Uncommitting: * * * * * * * * // Region: . . . . . . . . - // Expected Total: 0 x 32KB = 32KB + // Expected Total: 0 x sizek KB wb.NMTUncommitMemory(addr + 0*size, 8*size); output = new OutputAnalyzer(pb.start()); - output.shouldContain("Test (reserved=256KB, committed=0KB)"); + output.shouldContain("Test (reserved=" + 8*sizek + "KB, committed=0KB)"); } } From e956abefe67ae320cbf908a4f8d80900cb647696 Mon Sep 17 00:00:00 2001 From: Rachel Protacio Date: Tue, 7 Jun 2016 11:39:47 -0400 Subject: [PATCH 033/125] 8153858: Clean up needed when obtaining the package name from a fully qualified class name Consolidated and refactored code parsing fully qualified names. Includes gtest. Reviewed-by: dholmes, coleenp --- .../src/share/vm/classfile/classLoader.cpp | 65 +++++++++---- .../src/share/vm/classfile/classLoader.hpp | 4 +- .../share/vm/classfile/systemDictionary.cpp | 30 +++--- .../vm/classfile/systemDictionaryShared.hpp | 4 +- hotspot/src/share/vm/oops/instanceKlass.cpp | 69 +++++--------- hotspot/src/share/vm/oops/instanceKlass.hpp | 2 +- hotspot/src/share/vm/oops/method.hpp | 2 +- .../test/native/runtime/test_classLoader.cpp | 92 +++++++++++++++++++ .../native/runtime/test_instanceKlass.cpp | 35 +++++++ 9 files changed, 218 insertions(+), 85 deletions(-) create mode 100644 hotspot/test/native/runtime/test_classLoader.cpp create mode 100644 hotspot/test/native/runtime/test_instanceKlass.cpp diff --git a/hotspot/src/share/vm/classfile/classLoader.cpp b/hotspot/src/share/vm/classfile/classLoader.cpp index acc65eb9a8a..265b485c7d9 100644 --- a/hotspot/src/share/vm/classfile/classLoader.cpp +++ b/hotspot/src/share/vm/classfile/classLoader.cpp @@ -181,26 +181,59 @@ bool ClassLoader::string_ends_with(const char* str, const char* str_to_find) { } // Used to obtain the package name from a fully qualified class name. -// It is the responsibility of the caller to establish ResourceMark. -const char* ClassLoader::package_from_name(const char* class_name) { - const char* last_slash = strrchr(class_name, '/'); +// It is the responsibility of the caller to establish a ResourceMark. +const char* ClassLoader::package_from_name(const char* const class_name, bool* bad_class_name) { + if (class_name == NULL) { + if (bad_class_name != NULL) { + *bad_class_name = true; + } + return NULL; + } + + if (bad_class_name != NULL) { + *bad_class_name = false; + } + + const char* const last_slash = strrchr(class_name, '/'); if (last_slash == NULL) { // No package name return NULL; } - int length = last_slash - class_name; - // A class name could have just the slash character in the name, - // resulting in a negative length. + char* class_name_ptr = (char*) class_name; + // Skip over '['s + if (*class_name_ptr == '[') { + do { + class_name_ptr++; + } while (*class_name_ptr == '['); + + // Fully qualified class names should not contain a 'L'. + // Set bad_class_name to true to indicate that the package name + // could not be obtained due to an error condition. + // In this situation, is_same_class_package returns false. + if (*class_name_ptr == 'L') { + if (bad_class_name != NULL) { + *bad_class_name = true; + } + return NULL; + } + } + + int length = last_slash - class_name_ptr; + + // A class name could have just the slash character in the name. if (length <= 0) { // No package name + if (bad_class_name != NULL) { + *bad_class_name = true; + } return NULL; } // drop name after last slash (including slash) // Ex., "java/lang/String.class" => "java/lang" char* pkg_name = NEW_RESOURCE_ARRAY(char, length + 1); - strncpy(pkg_name, class_name, length); + strncpy(pkg_name, class_name_ptr, length); *(pkg_name+length) = '\0'; return (const char *)pkg_name; @@ -1117,13 +1150,11 @@ bool ClassLoader::add_package(const char *fullq_class_name, s2 classpath_index, assert(fullq_class_name != NULL, "just checking"); // Get package name from fully qualified class name. - const char *cp = strrchr(fullq_class_name, '/'); + ResourceMark rm; + const char *cp = package_from_name(fullq_class_name); if (cp != NULL) { - int len = cp - fullq_class_name; - PackageEntryTable* pkg_entry_tbl = - ClassLoaderData::the_null_class_loader_data()->packages(); - TempNewSymbol pkg_symbol = - SymbolTable::new_symbol(fullq_class_name, len, CHECK_false); + PackageEntryTable* pkg_entry_tbl = ClassLoaderData::the_null_class_loader_data()->packages(); + TempNewSymbol pkg_symbol = SymbolTable::new_symbol(cp, CHECK_false); PackageEntry* pkg_entry = pkg_entry_tbl->lookup_only(pkg_symbol); if (pkg_entry != NULL) { assert(classpath_index != -1, "Unexpected classpath_index"); @@ -1231,11 +1262,9 @@ s2 ClassLoader::classloader_type(Symbol* class_name, ClassPathEntry* e, int clas // jimage, it is determined by the class path entry. jshort loader_type = ClassLoader::APP_LOADER; if (e->is_jrt()) { - int length = 0; - const jbyte* pkg_string = InstanceKlass::package_from_name(class_name, length); - if (pkg_string != NULL) { - ResourceMark rm; - TempNewSymbol pkg_name = SymbolTable::new_symbol((const char*)pkg_string, length, THREAD); + ResourceMark rm; + TempNewSymbol pkg_name = InstanceKlass::package_from_name(class_name, CHECK_0); + if (pkg_name != NULL) { const char* pkg_name_C_string = (const char*)(pkg_name->as_C_string()); ClassPathImageEntry* cpie = (ClassPathImageEntry*)e; JImageFile* jimage = cpie->jimage(); diff --git a/hotspot/src/share/vm/classfile/classLoader.hpp b/hotspot/src/share/vm/classfile/classLoader.hpp index 1688373f2cc..c59697c52cd 100644 --- a/hotspot/src/share/vm/classfile/classLoader.hpp +++ b/hotspot/src/share/vm/classfile/classLoader.hpp @@ -444,7 +444,9 @@ class ClassLoader: AllStatic { static bool string_ends_with(const char* str, const char* str_to_find); // obtain package name from a fully qualified class name - static const char* package_from_name(const char* class_name); + // *bad_class_name is set to true if there's a problem with parsing class_name, to + // distinguish from a class_name with no package name, as both cases have a NULL return value + static const char* package_from_name(const char* const class_name, bool* bad_class_name = NULL); static bool is_jrt(const char* name) { return string_ends_with(name, MODULES_IMAGE_NAME); } diff --git a/hotspot/src/share/vm/classfile/systemDictionary.cpp b/hotspot/src/share/vm/classfile/systemDictionary.cpp index 28b79768fa5..aaa2ad5dda1 100644 --- a/hotspot/src/share/vm/classfile/systemDictionary.cpp +++ b/hotspot/src/share/vm/classfile/systemDictionary.cpp @@ -70,6 +70,7 @@ #include "services/threadService.hpp" #include "trace/traceMacros.hpp" #include "utilities/macros.hpp" +#include "utilities/stringUtils.hpp" #include "utilities/ticks.hpp" #if INCLUDE_CDS #include "classfile/sharedClassUtil.hpp" @@ -1154,12 +1155,10 @@ Klass* SystemDictionary::resolve_from_stream(Symbol* class_name, // It is illegal to define classes in the "java." package from // JVM_DefineClass or jni_DefineClass unless you're the bootclassloader ResourceMark rm(THREAD); - char* name = parsed_name->as_C_string(); - char* index = strrchr(name, '/'); - *index = '\0'; // chop to just the package name - while ((index = strchr(name, '/')) != NULL) { - *index = '.'; // replace '/' with '.' in package name - } + TempNewSymbol pkg_name = InstanceKlass::package_from_name(parsed_name, CHECK_NULL); + assert(pkg_name != NULL, "Error in parsing package name starting with 'java/'"); + char* name = pkg_name->as_C_string(); + StringUtils::replace_no_expand(name, "/", "."); const char* msg_text = "Prohibited package name: "; size_t len = strlen(msg_text) + strlen(name) + 1; char* message = NEW_RESOURCE_ARRAY(char, len); @@ -1257,6 +1256,7 @@ instanceKlassHandle SystemDictionary::load_shared_class( bool SystemDictionary::is_shared_class_visible(Symbol* class_name, instanceKlassHandle ik, Handle class_loader, TRAPS) { + ResourceMark rm; int path_index = ik->shared_classpath_index(); SharedClassPathEntry* ent = (SharedClassPathEntry*)FileMapInfo::shared_classpath(path_index); @@ -1270,12 +1270,11 @@ bool SystemDictionary::is_shared_class_visible(Symbol* class_name, TempNewSymbol pkg_name = NULL; PackageEntry* pkg_entry = NULL; ModuleEntry* mod_entry = NULL; - int length = 0; + const char* pkg_string = NULL; ClassLoaderData* loader_data = class_loader_data(class_loader); - const jbyte* pkg_string = InstanceKlass::package_from_name(class_name, length); - if (pkg_string != NULL) { - pkg_name = SymbolTable::new_symbol((const char*)pkg_string, - length, CHECK_(false)); + pkg_name = InstanceKlass::package_from_name(class_name, CHECK_false); + if (pkg_name != NULL) { + pkg_string = pkg_name->as_C_string(); if (loader_data != NULL) { pkg_entry = loader_data->packages()->lookup_only(pkg_name); } @@ -1432,15 +1431,14 @@ instanceKlassHandle SystemDictionary::load_instance_class(Symbol* class_name, Ha instanceKlassHandle nh = instanceKlassHandle(); // null Handle if (class_loader.is_null()) { - int length = 0; + ResourceMark rm; PackageEntry* pkg_entry = NULL; bool search_only_bootloader_append = false; ClassLoaderData *loader_data = class_loader_data(class_loader); // Find the package in the boot loader's package entry table. - const jbyte* pkg_string = InstanceKlass::package_from_name(class_name, length); - if (pkg_string != NULL) { - TempNewSymbol pkg_name = SymbolTable::new_symbol((const char*)pkg_string, length, CHECK_(nh)); + TempNewSymbol pkg_name = InstanceKlass::package_from_name(class_name, CHECK_NULL); + if (pkg_name != NULL) { pkg_entry = loader_data->packages()->lookup_only(pkg_name); } @@ -1477,7 +1475,7 @@ instanceKlassHandle SystemDictionary::load_instance_class(Symbol* class_name, Ha assert(!DumpSharedSpaces, "Archive dumped after module system initialization"); // After the module system has been initialized, check if the class' // package is in a module defined to the boot loader. - if (pkg_string == NULL || pkg_entry == NULL || pkg_entry->in_unnamed_module()) { + if (pkg_name == NULL || pkg_entry == NULL || pkg_entry->in_unnamed_module()) { // Class is either in the unnamed package, in a named package // within a module not defined to the boot loader or in a // a named package within the unnamed module. In all cases, diff --git a/hotspot/src/share/vm/classfile/systemDictionaryShared.hpp b/hotspot/src/share/vm/classfile/systemDictionaryShared.hpp index 51db47c3387..44815e72930 100644 --- a/hotspot/src/share/vm/classfile/systemDictionaryShared.hpp +++ b/hotspot/src/share/vm/classfile/systemDictionaryShared.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -48,7 +48,7 @@ public: static bool is_shared_class_visible_for_classloader( instanceKlassHandle ik, Handle class_loader, - const jbyte* pkg_string, + const char* pkg_string, Symbol* pkg_name, PackageEntry* pkg_entry, ModuleEntry* mod_entry, diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index 02161471b01..58135b4a5ff 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -2182,39 +2182,21 @@ const char* InstanceKlass::signature_name() const { return dest; } -const jbyte* InstanceKlass::package_from_name(const Symbol* name, int& length) { - ResourceMark rm; - length = 0; +// Used to obtain the package name from a fully qualified class name. +Symbol* InstanceKlass::package_from_name(const Symbol* name, TRAPS) { if (name == NULL) { return NULL; } else { - const jbyte* base_name = name->base(); - const jbyte* last_slash = UTF8::strrchr(base_name, name->utf8_length(), '/'); - - if (last_slash == NULL) { - // No package name + if (name->utf8_length() <= 0) { return NULL; - } else { - // Skip over '['s - if (*base_name == '[') { - do { - base_name++; - } while (*base_name == '['); - if (*base_name != 'L') { - // Fully qualified class names should not contain a 'L'. - // Set length to -1 to indicate that the package name - // could not be obtained due to an error condition. - // In this situtation, is_same_class_package returns false. - length = -1; - return NULL; - } - } - - // Found the package name, look it up in the symbol table. - length = last_slash - base_name; - assert(length > 0, "Bad length for package name"); - return base_name; } + ResourceMark rm; + const char* package_name = ClassLoader::package_from_name((const char*) name->as_C_string()); + if (package_name == NULL) { + return NULL; + } + Symbol* pkg_name = SymbolTable::new_symbol(package_name, THREAD); + return pkg_name; } } @@ -2230,12 +2212,9 @@ ModuleEntry* InstanceKlass::module() const { } void InstanceKlass::set_package(ClassLoaderData* loader_data, TRAPS) { - int length = 0; - const jbyte* base_name = package_from_name(name(), length); - - if (base_name != NULL && loader_data != NULL) { - TempNewSymbol pkg_name = SymbolTable::new_symbol((const char*)base_name, length, CHECK); + TempNewSymbol pkg_name = package_from_name(name(), CHECK); + if (pkg_name != NULL && loader_data != NULL) { // Find in class loader's package entry table. _package_entry = loader_data->packages()->lookup_only(pkg_name); @@ -2331,20 +2310,18 @@ bool InstanceKlass::is_same_class_package(oop class_loader1, const Symbol* class if (class_loader1 != class_loader2) { return false; } else if (class_name1 == class_name2) { - return true; // skip painful bytewise comparison + return true; } else { ResourceMark rm; - // The Symbol*'s are in UTF8 encoding. Since we only need to check explicitly - // for ASCII characters ('/', 'L', '['), we can keep them in UTF8 encoding. - // Otherwise, we just compare jbyte values between the strings. - int length1 = 0; - int length2 = 0; - const jbyte *name1 = package_from_name(class_name1, length1); - const jbyte *name2 = package_from_name(class_name2, length2); + bool bad_class_name = false; + const char* name1 = ClassLoader::package_from_name((const char*) class_name1->as_C_string(), &bad_class_name); + if (bad_class_name) { + return false; + } - if ((length1 < 0) || (length2 < 0)) { - // error occurred parsing package name. + const char* name2 = ClassLoader::package_from_name((const char*) class_name2->as_C_string(), &bad_class_name); + if (bad_class_name) { return false; } @@ -2354,13 +2331,13 @@ bool InstanceKlass::is_same_class_package(oop class_loader1, const Symbol* class return name1 == name2; } - // Check that package part is identical - return UTF8::equal(name1, length1, name2, length2); + // Check that package is identical + return (strcmp(name1, name2) == 0); } } // Returns true iff super_method can be overridden by a method in targetclassname -// See JSL 3rd edition 8.4.6.1 +// See JLS 3rd edition 8.4.6.1 // Assumes name-signature match // "this" is InstanceKlass of super_method which must exist // note that the InstanceKlass of the method in the targetclassname has not always been created yet diff --git a/hotspot/src/share/vm/oops/instanceKlass.hpp b/hotspot/src/share/vm/oops/instanceKlass.hpp index 494173b3ded..000215d14a0 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.hpp +++ b/hotspot/src/share/vm/oops/instanceKlass.hpp @@ -1108,7 +1108,7 @@ public: // Naming const char* signature_name() const; - static const jbyte* package_from_name(const Symbol* name, int& length); + static Symbol* package_from_name(const Symbol* name, TRAPS); // GC specific object visitors // diff --git a/hotspot/src/share/vm/oops/method.hpp b/hotspot/src/share/vm/oops/method.hpp index 6b852d37502..f1bbf9ea84f 100644 --- a/hotspot/src/share/vm/oops/method.hpp +++ b/hotspot/src/share/vm/oops/method.hpp @@ -246,7 +246,7 @@ class Method : public Metadata { int code_size() const { return constMethod()->code_size(); } // method size in words - int method_size() const { return sizeof(Method)/wordSize + is_native() ? 2 : 0; } + int method_size() const { return sizeof(Method)/wordSize + ( is_native() ? 2 : 0 ); } // constant pool for Klass* holding this method ConstantPool* constants() const { return constMethod()->constants(); } diff --git a/hotspot/test/native/runtime/test_classLoader.cpp b/hotspot/test/native/runtime/test_classLoader.cpp new file mode 100644 index 00000000000..8ca5ba303d0 --- /dev/null +++ b/hotspot/test/native/runtime/test_classLoader.cpp @@ -0,0 +1,92 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +#include "classfile/classLoader.hpp" +#include "memory/resourceArea.hpp" +#include "unittest.hpp" + +// Tests ClassLoader::package_from_name() +TEST_VM(classLoader, null_class_name) { + ResourceMark rm; + bool bad_class_name = false; + const char* retval= ClassLoader::package_from_name(NULL, &bad_class_name); + ASSERT_TRUE(bad_class_name) << "Function did not set bad_class_name with NULL class name"; + ASSERT_STREQ(retval, NULL) << "Wrong package for NULL class name pointer"; +} + +TEST_VM(classLoader, empty_class_name) { + ResourceMark rm; + const char* retval = ClassLoader::package_from_name(""); + ASSERT_STREQ(retval, NULL) << "Wrong package for empty string"; +} + +TEST_VM(classLoader, no_slash) { + ResourceMark rm; + const char* retval = ClassLoader::package_from_name("L"); + ASSERT_STREQ(retval, NULL) << "Wrong package for class with no slashes"; +} + +TEST_VM(classLoader, just_slash) { + ResourceMark rm; + bool bad_class_name = false; + const char* retval = ClassLoader::package_from_name("/", &bad_class_name); + ASSERT_TRUE(bad_class_name) << "Function did not set bad_class_name with package of length 0"; + ASSERT_STREQ(retval, NULL) << "Wrong package for class with just slash"; +} + +TEST_VM(classLoader, multiple_slashes) { + ResourceMark rm; + const char* retval = ClassLoader::package_from_name("///"); + ASSERT_STREQ(retval, "//") << "Wrong package for class with just slashes"; +} + +TEST_VM(classLoader, standard_case_1) { + ResourceMark rm; + bool bad_class_name = true; + const char* retval = ClassLoader::package_from_name("package/class", &bad_class_name); + ASSERT_FALSE(bad_class_name) << "Function did not reset bad_class_name"; + ASSERT_STREQ(retval, "package") << "Wrong package for class with one slash"; +} + +TEST_VM(classLoader, standard_case_2) { + ResourceMark rm; + const char* retval = ClassLoader::package_from_name("package/folder/class"); + ASSERT_STREQ(retval, "package/folder") << "Wrong package for class with multiple slashes"; +} + +TEST_VM(classLoader, class_array) { + ResourceMark rm; + bool bad_class_name = false; + const char* retval = ClassLoader::package_from_name("[package/class", &bad_class_name); + ASSERT_FALSE(bad_class_name) << "Function set bad_class_name with class array"; + ASSERT_STREQ(retval, "package") << "Wrong package for class with leading bracket"; +} + +TEST_VM(classLoader, class_object_array) { + ResourceMark rm; + bool bad_class_name = false; + const char* retval = ClassLoader::package_from_name("[Lpackage/class", &bad_class_name); + ASSERT_TRUE(bad_class_name) << "Function did not set bad_class_name with array of class objects"; + ASSERT_STREQ(retval, NULL) << "Wrong package for class with leading '[L'"; +} diff --git a/hotspot/test/native/runtime/test_instanceKlass.cpp b/hotspot/test/native/runtime/test_instanceKlass.cpp new file mode 100644 index 00000000000..179aae5b854 --- /dev/null +++ b/hotspot/test/native/runtime/test_instanceKlass.cpp @@ -0,0 +1,35 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +#include "classfile/symbolTable.hpp" +#include "memory/resourceArea.hpp" +#include "oops/instanceKlass.hpp" +#include "unittest.hpp" + +// Tests InstanceKlass::package_from_name() +TEST_VM(instanceKlass, null_symbol) { + ResourceMark rm; + TempNewSymbol package_sym = InstanceKlass::package_from_name(NULL, NULL); + ASSERT_TRUE(package_sym == NULL) << "Wrong package for NULL symbol"; +} From 4a9d6dcbba789bc9fd9c9d5e3e72b85ebc12cf8e Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Tue, 7 Jun 2016 18:26:10 +0200 Subject: [PATCH 034/125] 8158938: AIX: some more new hotspot build fixes Reviewed-by: erikj --- hotspot/make/lib/JvmOverrideFiles.gmk | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/hotspot/make/lib/JvmOverrideFiles.gmk b/hotspot/make/lib/JvmOverrideFiles.gmk index 1ffcb7455ce..78a007cc39d 100644 --- a/hotspot/make/lib/JvmOverrideFiles.gmk +++ b/hotspot/make/lib/JvmOverrideFiles.gmk @@ -153,6 +153,13 @@ else ifeq ($(OPENJDK_TARGET_OS), aix) # mode, so don't optimize sharedRuntimeTrig.cpp at all. BUILD_LIBJVM_sharedRuntimeTrig.cpp_CXXFLAGS := $(CXX_O_FLAG_NONE) + ifneq ($(DEBUG_LEVEL),slowdebug) + # Compiling jvmtiEnterTrace.cpp with full optimization needs more than 30min + # (mostly because of '-qhot=level=1' and the more than 1300 'log_trace' calls + # which cause a lot of template expansion). + BUILD_LIBJVM_jvmtiEnterTrace.cpp_OPTIMIZATION := LOW + endif + # Disable ELF decoder on AIX (AIX uses XCOFF). JVM_EXCLUDE_PATTERNS += elf From 47309c37159d560086a27d4b5ac7f05958f373e0 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Tue, 7 Jun 2016 15:34:22 -0400 Subject: [PATCH 035/125] 8158297: Lack of proper checking of non-well formed elements in CONSTANT_Utf8_info's structure Disallow // in class file names during parsing and throw ClassNotFoundException Reviewed-by: sspitsyn, rehn, gtriantafill --- .../share/vm/classfile/classFileParser.cpp | 13 +- .../classFileParserBug/TestBadClassName.java | 57 +++++++++ .../classFileParserBug/UseBadInterface1.jcod | 120 ++++++++++++++++++ .../classFileParserBug/UseBadInterface2.jcod | 120 ++++++++++++++++++ .../classFileParserBug/p1/BadInterface1.jcod | 62 +++++++++ .../classFileParserBug/p1/BadInterface2.jcod | 62 +++++++++ 6 files changed, 432 insertions(+), 2 deletions(-) create mode 100644 hotspot/test/runtime/classFileParserBug/TestBadClassName.java create mode 100644 hotspot/test/runtime/classFileParserBug/UseBadInterface1.jcod create mode 100644 hotspot/test/runtime/classFileParserBug/UseBadInterface2.jcod create mode 100644 hotspot/test/runtime/classFileParserBug/p1/BadInterface1.jcod create mode 100644 hotspot/test/runtime/classFileParserBug/p1/BadInterface2.jcod diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index 1d5f4e4c042..a09fc8e14d0 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -4673,6 +4673,7 @@ void ClassFileParser::verify_legal_utf8(const unsigned char* buffer, } // Unqualified names may not contain the characters '.', ';', '[', or '/'. +// In class names, '/' separates unqualified names. This is verified in this function also. // Method names also may not contain the characters '<' or '>', unless // or . Note that method names may not be or in this // method. Because these names have been checked as special cases before @@ -4698,8 +4699,16 @@ bool ClassFileParser::verify_unqualified_name(const char* name, if (ch == ';' || ch == '[' ) { return false; // do not permit '.', ';', or '[' } - if (type != ClassFileParser::LegalClass && ch == '/') { - return false; // do not permit '/' unless it's class name + if (ch == '/') { + // check for '//' or leading or trailing '/' which are not legal + // unqualified name must not be empty + if (type == ClassFileParser::LegalClass) { + if (p == name || p+1 >= name+length || *(p+1) == '/') { + return false; + } + } else { + return false; // do not permit '/' unless it's class name + } } if (type == ClassFileParser::LegalMethod && (ch == '<' || ch == '>')) { return false; // do not permit '<' or '>' in method names diff --git a/hotspot/test/runtime/classFileParserBug/TestBadClassName.java b/hotspot/test/runtime/classFileParserBug/TestBadClassName.java new file mode 100644 index 00000000000..d742711b7f1 --- /dev/null +++ b/hotspot/test/runtime/classFileParserBug/TestBadClassName.java @@ -0,0 +1,57 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +/* + * @test + * @bug 8158297 + * @summary Constant pool utf8 entry for class name cannot have empty qualified name '//' + * @compile p1/BadInterface1.jcod + * @compile p1/BadInterface2.jcod + * @compile UseBadInterface1.jcod + * @compile UseBadInterface2.jcod + * @run main/othervm -Xverify:all TestBadClassName + */ + +public class TestBadClassName { + public static void main(String args[]) throws Throwable { + + System.out.println("Regression test for bug 8042660"); + + // Test class name with p1//BadInterface2 + try { + Class newClass = Class.forName("UseBadInterface1"); + throw new RuntimeException("Expected ClassFormatError exception not thrown"); + } catch (java.lang.ClassFormatError e) { + System.out.println("Test UseBadInterface1 passed test case with illegal class name"); + } + + // Test class name with p1/BadInterface2/ + try { + Class newClass = Class.forName("UseBadInterface2"); + throw new RuntimeException("Expected ClassFormatError exception not thrown"); + } catch (java.lang.ClassFormatError e) { + System.out.println("Test UseBadInterface1 passed test case with illegal class name"); + } + } +} diff --git a/hotspot/test/runtime/classFileParserBug/UseBadInterface1.jcod b/hotspot/test/runtime/classFileParserBug/UseBadInterface1.jcod new file mode 100644 index 00000000000..243d47f7472 --- /dev/null +++ b/hotspot/test/runtime/classFileParserBug/UseBadInterface1.jcod @@ -0,0 +1,120 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +// jcod file for UseBadInterface1.java +// class UseBadInterface1 implements p1.BadInterface1 { +// int i; +// UseBadInterface1() {} +// public static void main(java.lang.String[] unused) { } +// } + +class UseBadInterface1 { + 0xCAFEBABE; + 0; // minor version + 53; // version + [] { // Constant Pool + ; // first element is empty + Method #3 #10; // #1 + Utf8 "UseBadInterface1.java"; // #2 + class #4; // #3 + Utf8 "java/lang/Object"; // #4 + class #8; // #5 + Utf8 "([Ljava/lang/String;)V"; // #6 + class #11; // #7 + Utf8 "UseBadInterface1"; // #8 + Utf8 "main"; // #9 + NameAndType #17 #13; // #10 + Utf8 "p1//BadInterface1"; // #11 + Utf8 "SourceFile"; // #12 + Utf8 "()V"; // #13 + Utf8 "I"; // #14 + Utf8 "Code"; // #15 + Utf8 "i"; // #16 + Utf8 ""; // #17 + } // Constant Pool + + 0x0020; // access + #5;// this_cpx + #3;// super_cpx + + [] { // Interfaces + #7; + } // Interfaces + + [] { // fields + { // Member + 0x0000; // access + #16; // name_cpx + #14; // sig_cpx + [] { // Attributes + } // Attributes + } // Member + } // fields + + [] { // methods + { // Member + 0x0000; // access + #17; // name_cpx + #13; // sig_cpx + [] { // Attributes + Attr(#15) { // Code + 1; // max_stack + 1; // max_locals + Bytes[]{ + 0x2AB70001B1; + }; + [] { // Traps + } // end Traps + [] { // Attributes + } // Attributes + } // end Code + } // Attributes + } // Member + ; + { // Member + 0x0009; // access + #9; // name_cpx + #6; // sig_cpx + [] { // Attributes + Attr(#15) { // Code + 0; // max_stack + 1; // max_locals + Bytes[]{ + 0xB1; + }; + [] { // Traps + } // end Traps + [] { // Attributes + } // Attributes + } // end Code + } // Attributes + } // Member + } // methods + + [] { // Attributes + Attr(#12) { // SourceFile + #2; + } // end SourceFile + } // Attributes +} // end class UseBadInterface1 diff --git a/hotspot/test/runtime/classFileParserBug/UseBadInterface2.jcod b/hotspot/test/runtime/classFileParserBug/UseBadInterface2.jcod new file mode 100644 index 00000000000..903d31cddd6 --- /dev/null +++ b/hotspot/test/runtime/classFileParserBug/UseBadInterface2.jcod @@ -0,0 +1,120 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +// jcod file for UseBadInterface2.java +// class UseBadInterface2 implements p1.BadInterface2 { +// int i; +// UseBadInterface2() {} +// public static void main(java.lang.String[] unused) { } +// } + +class UseBadInterface2 { + 0xCAFEBABE; + 0; // minor version + 53; // version + [] { // Constant Pool + ; // first element is empty + Method #3 #10; // #1 + Utf8 "UseBadInterface2.java"; // #2 + class #4; // #3 + Utf8 "java/lang/Object"; // #4 + class #8; // #5 + Utf8 "([Ljava/lang/String;)V"; // #6 + class #11; // #7 + Utf8 "UseBadInterface2"; // #8 + Utf8 "main"; // #9 + NameAndType #17 #13; // #10 + Utf8 "p1/BadInterface2/"; // #11 + Utf8 "SourceFile"; // #12 + Utf8 "()V"; // #13 + Utf8 "I"; // #14 + Utf8 "Code"; // #15 + Utf8 "i"; // #16 + Utf8 ""; // #17 + } // Constant Pool + + 0x0020; // access + #5;// this_cpx + #3;// super_cpx + + [] { // Interfaces + #7; + } // Interfaces + + [] { // fields + { // Member + 0x0000; // access + #16; // name_cpx + #14; // sig_cpx + [] { // Attributes + } // Attributes + } // Member + } // fields + + [] { // methods + { // Member + 0x0000; // access + #17; // name_cpx + #13; // sig_cpx + [] { // Attributes + Attr(#15) { // Code + 1; // max_stack + 1; // max_locals + Bytes[]{ + 0x2AB70001B1; + }; + [] { // Traps + } // end Traps + [] { // Attributes + } // Attributes + } // end Code + } // Attributes + } // Member + ; + { // Member + 0x0009; // access + #9; // name_cpx + #6; // sig_cpx + [] { // Attributes + Attr(#15) { // Code + 0; // max_stack + 1; // max_locals + Bytes[]{ + 0xB1; + }; + [] { // Traps + } // end Traps + [] { // Attributes + } // Attributes + } // end Code + } // Attributes + } // Member + } // methods + + [] { // Attributes + Attr(#12) { // SourceFile + #2; + } // end SourceFile + } // Attributes +} // end class UseBadInterface2 diff --git a/hotspot/test/runtime/classFileParserBug/p1/BadInterface1.jcod b/hotspot/test/runtime/classFileParserBug/p1/BadInterface1.jcod new file mode 100644 index 00000000000..f19a2653e5a --- /dev/null +++ b/hotspot/test/runtime/classFileParserBug/p1/BadInterface1.jcod @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +// Interface that should get a ClassFormatException for the "//" in the name + +// package p1; +// public interface cls1 {} + +class p1//BadInterface1 { + 0xCAFEBABE; + 0; // minor version + 53; // version + [] { // Constant Pool + ; // first element is empty + class #5; // #1 + class #6; // #2 + Utf8 "SourceFile"; // #3 + Utf8 "BadInterface1.java"; // #4 + Utf8 "p1//BadInterface1"; // #5 + Utf8 "java/lang/Object"; // #6 + } // Constant Pool + + 0x0601; // access + #1;// this_cpx + #2;// super_cpx + + [] { // Interfaces + } // Interfaces + + [] { // fields + } // fields + + [] { // methods + } // methods + + [] { // Attributes + Attr(#3) { // SourceFile + #4; + } // end SourceFile + } // Attributes +} // end class p1//BadInterface1 diff --git a/hotspot/test/runtime/classFileParserBug/p1/BadInterface2.jcod b/hotspot/test/runtime/classFileParserBug/p1/BadInterface2.jcod new file mode 100644 index 00000000000..33c34f5944d --- /dev/null +++ b/hotspot/test/runtime/classFileParserBug/p1/BadInterface2.jcod @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +// Interface that should get a ClassFormatException for the trailing "/" in the name + +// package p1; +// public interface cls1 {} + +class p1/BadInterface2/ { + 0xCAFEBABE; + 0; // minor version + 53; // version + [] { // Constant Pool + ; // first element is empty + class #5; // #1 + class #6; // #2 + Utf8 "SourceFile"; // #3 + Utf8 "BadInterface2.java"; // #4 + Utf8 "p1/BadInterface2/"; // #5 + Utf8 "java/lang/Object"; // #6 + } // Constant Pool + + 0x0601; // access + #1;// this_cpx + #2;// super_cpx + + [] { // Interfaces + } // Interfaces + + [] { // fields + } // fields + + [] { // methods + } // methods + + [] { // Attributes + Attr(#3) { // SourceFile + #4; + } // end SourceFile + } // Attributes +} // end class p1/BadInterface2 From 23e05cabc57f46c5102541616d00d881c7e1511f Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Wed, 8 Jun 2016 11:15:49 +0200 Subject: [PATCH 036/125] 8155638: Resource allocated BitMaps are often cleared twice Reviewed-by: neliasso, kvn --- hotspot/src/cpu/x86/vm/c1_LinearScan_x86.cpp | 1 - hotspot/src/share/vm/c1/c1_IR.cpp | 8 ++------ hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 1 - hotspot/src/share/vm/c1/c1_LinearScan.cpp | 18 +++++++----------- hotspot/src/share/vm/c1/c1_ValueSet.hpp | 1 - hotspot/src/share/vm/ci/ciMethod.cpp | 1 - .../src/share/vm/compiler/methodLiveness.cpp | 14 -------------- hotspot/src/share/vm/utilities/bitMap.hpp | 1 - .../src/share/vm/utilities/bitMap.inline.hpp | 4 ---- 9 files changed, 9 insertions(+), 40 deletions(-) diff --git a/hotspot/src/cpu/x86/vm/c1_LinearScan_x86.cpp b/hotspot/src/cpu/x86/vm/c1_LinearScan_x86.cpp index 5c411814df7..e291000eab0 100644 --- a/hotspot/src/cpu/x86/vm/c1_LinearScan_x86.cpp +++ b/hotspot/src/cpu/x86/vm/c1_LinearScan_x86.cpp @@ -68,7 +68,6 @@ void LinearScan::allocate_fpu_stack() { if (b->number_of_preds() > 1) { int id = b->first_lir_instruction_id(); ResourceBitMap regs(FrameMap::nof_fpu_regs); - regs.clear(); iw.walk_to(id); // walk after the first instruction (always a label) of the block assert(iw.current_position() == id, "did not walk completely to id"); diff --git a/hotspot/src/share/vm/c1/c1_IR.cpp b/hotspot/src/share/vm/c1/c1_IR.cpp index c1c72cf74f5..69d4ec1291f 100644 --- a/hotspot/src/share/vm/c1/c1_IR.cpp +++ b/hotspot/src/share/vm/c1/c1_IR.cpp @@ -147,10 +147,8 @@ IRScope::IRScope(Compilation* compilation, IRScope* caller, int caller_bci, ciMe _wrote_volatile = false; _start = NULL; - if (osr_bci == -1) { - _requires_phi_function.clear(); - } else { - // selective creation of phi functions is not possibel in osr-methods + if (osr_bci != -1) { + // selective creation of phi functions is not possibel in osr-methods _requires_phi_function.set_range(0, method->max_locals()); } @@ -540,7 +538,6 @@ ComputeLinearScanOrder::ComputeLinearScanOrder(Compilation* c, BlockBegin* start { TRACE_LINEAR_SCAN(2, tty->print_cr("***** computing linear-scan block order")); - init_visited(); count_edges(start_block, NULL); if (compilation()->is_profiling()) { @@ -646,7 +643,6 @@ void ComputeLinearScanOrder::mark_loops() { TRACE_LINEAR_SCAN(3, tty->print_cr("----- marking loops")); _loop_map = BitMap2D(_num_loops, _max_block_id); - _loop_map.clear(); for (int i = _loop_end_blocks.length() - 1; i >= 0; i--) { BlockBegin* loop_end = _loop_end_blocks.at(i); diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index ae49fc36878..53701de2b3e 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -1387,7 +1387,6 @@ Instruction* LIRGenerator::instruction_for_vreg(int reg_num) { void LIRGenerator::set_vreg_flag(int vreg_num, VregFlag f) { if (_vreg_flags.size_in_bits() == 0) { BitMap2D temp(100, num_vreg_flags); - temp.clear(); _vreg_flags = temp; } _vreg_flags.at_put_grow(vreg_num, f, true); diff --git a/hotspot/src/share/vm/c1/c1_LinearScan.cpp b/hotspot/src/share/vm/c1/c1_LinearScan.cpp index dd45f5bf3b9..18397d6118f 100644 --- a/hotspot/src/share/vm/c1/c1_LinearScan.cpp +++ b/hotspot/src/share/vm/c1/c1_LinearScan.cpp @@ -562,14 +562,13 @@ void LinearScan::compute_local_live_sets() { LIR_OpVisitState visitor; BitMap2D local_interval_in_loop = BitMap2D(_num_virtual_regs, num_loops()); - local_interval_in_loop.clear(); // iterate all blocks for (int i = 0; i < num_blocks; i++) { BlockBegin* block = block_at(i); - ResourceBitMap live_gen(live_size); live_gen.clear(); - ResourceBitMap live_kill(live_size); live_kill.clear(); + ResourceBitMap live_gen(live_size); + ResourceBitMap live_kill(live_size); if (block->is_set(BlockBegin::exception_entry_flag)) { // Phi functions at the begin of an exception handler are @@ -715,8 +714,8 @@ void LinearScan::compute_local_live_sets() { block->set_live_gen (live_gen); block->set_live_kill(live_kill); - block->set_live_in (ResourceBitMap(live_size)); block->live_in().clear(); - block->set_live_out (ResourceBitMap(live_size)); block->live_out().clear(); + block->set_live_in (ResourceBitMap(live_size)); + block->set_live_out (ResourceBitMap(live_size)); TRACE_LINEAR_SCAN(4, tty->print("live_gen B%d ", block->block_id()); print_bitmap(block->live_gen())); TRACE_LINEAR_SCAN(4, tty->print("live_kill B%d ", block->block_id()); print_bitmap(block->live_kill())); @@ -741,7 +740,7 @@ void LinearScan::compute_global_live_sets() { bool change_occurred; bool change_occurred_in_block; int iteration_count = 0; - ResourceBitMap live_out(live_set_size()); live_out.clear(); // scratch set for calculations + ResourceBitMap live_out(live_set_size()); // scratch set for calculations // Perform a backward dataflow analysis to compute live_out and live_in for each block. // The loop is executed until a fixpoint is reached (no changes in an iteration) @@ -827,7 +826,6 @@ void LinearScan::compute_global_live_sets() { // check that the live_in set of the first block is empty ResourceBitMap live_in_args(ir()->start()->live_in().size()); - live_in_args.clear(); if (!ir()->start()->live_in().is_same(live_in_args)) { #ifdef ASSERT tty->print_cr("Error: live_in set of first block must be empty (when this fails, virtual registers are used before they are defined)"); @@ -1774,8 +1772,8 @@ void LinearScan::resolve_data_flow() { int num_blocks = block_count(); MoveResolver move_resolver(this); - ResourceBitMap block_completed(num_blocks); block_completed.clear(); - ResourceBitMap already_resolved(num_blocks); already_resolved.clear(); + ResourceBitMap block_completed(num_blocks); + ResourceBitMap already_resolved(num_blocks); int i; for (i = 0; i < num_blocks; i++) { @@ -3750,7 +3748,6 @@ void MoveResolver::verify_before_resolve() { ResourceBitMap used_regs(LinearScan::nof_regs + allocator()->frame_map()->argcount() + allocator()->max_spills()); - used_regs.clear(); if (!_multiple_reads_allowed) { for (i = 0; i < _mapping_from.length(); i++) { Interval* it = _mapping_from.at(i); @@ -6319,7 +6316,6 @@ void ControlFlowOptimizer::delete_unnecessary_jumps(BlockList* code) { void ControlFlowOptimizer::delete_jumps_to_return(BlockList* code) { #ifdef ASSERT ResourceBitMap return_converted(BlockBegin::number_of_blocks()); - return_converted.clear(); #endif for (int i = code->length() - 1; i >= 0; i--) { diff --git a/hotspot/src/share/vm/c1/c1_ValueSet.hpp b/hotspot/src/share/vm/c1/c1_ValueSet.hpp index 50538121cf8..69802a85c1a 100644 --- a/hotspot/src/share/vm/c1/c1_ValueSet.hpp +++ b/hotspot/src/share/vm/c1/c1_ValueSet.hpp @@ -53,7 +53,6 @@ class ValueSet: public CompilationResourceObj { }; inline ValueSet::ValueSet() : _map(Instruction::number_of_instructions()) { - _map.clear(); } diff --git a/hotspot/src/share/vm/ci/ciMethod.cpp b/hotspot/src/share/vm/ci/ciMethod.cpp index 2a4484850bb..a54c0a724de 100644 --- a/hotspot/src/share/vm/ci/ciMethod.cpp +++ b/hotspot/src/share/vm/ci/ciMethod.cpp @@ -449,7 +449,6 @@ ResourceBitMap ciMethod::live_local_oops_at_bci(int bci) { OopMapCache::compute_one_oop_map(get_Method(), bci, &mask); int mask_size = max_locals(); ResourceBitMap result(mask_size); - result.clear(); int i; for (i = 0; i < mask_size ; i++ ) { if (mask.is_oop(i)) result.set_bit(i); diff --git a/hotspot/src/share/vm/compiler/methodLiveness.cpp b/hotspot/src/share/vm/compiler/methodLiveness.cpp index e68d1244f75..8d82cc18175 100644 --- a/hotspot/src/share/vm/compiler/methodLiveness.cpp +++ b/hotspot/src/share/vm/compiler/methodLiveness.cpp @@ -137,11 +137,6 @@ MethodLiveness::MethodLiveness(Arena* arena, ciMethod* method) _arena = arena; _method = method; _bit_map_size_bits = method->max_locals(); - - -#ifdef COMPILER1 - _bci_block_start.clear(); -#endif } void MethodLiveness::compute_liveness() { @@ -587,14 +582,6 @@ MethodLiveness::BasicBlock::BasicBlock(MethodLiveness *analyzer, int start, int new (analyzer->arena()) GrowableArray(analyzer->arena(), 5, 0, NULL); _exception_predecessors = new (analyzer->arena()) GrowableArray(analyzer->arena(), 5, 0, NULL); - _normal_exit.clear(); - _exception_exit.clear(); - _entry.clear(); - - // this initialization is not strictly necessary. - // _gen and _kill are cleared at the beginning of compute_gen_kill_range() - _gen.clear(); - _kill.clear(); } @@ -1020,7 +1007,6 @@ MethodLivenessResult MethodLiveness::BasicBlock::get_liveness_at(ciMethod* metho _last_bci = bci; } - answer.clear(); answer.set_union(_normal_exit); answer.set_difference(_kill); answer.set_union(_gen); diff --git a/hotspot/src/share/vm/utilities/bitMap.hpp b/hotspot/src/share/vm/utilities/bitMap.hpp index bc5cb589929..01c94dae19c 100644 --- a/hotspot/src/share/vm/utilities/bitMap.hpp +++ b/hotspot/src/share/vm/utilities/bitMap.hpp @@ -435,7 +435,6 @@ class BitMap2D VALUE_OBJ_CLASS_SPEC { void clear_bit(idx_t slot_index, idx_t bit_within_slot_index); void at_put(idx_t slot_index, idx_t bit_within_slot_index, bool value); void at_put_grow(idx_t slot_index, idx_t bit_within_slot_index, bool value); - void clear(); }; // Closure for iterating over BitMaps diff --git a/hotspot/src/share/vm/utilities/bitMap.inline.hpp b/hotspot/src/share/vm/utilities/bitMap.inline.hpp index 49521d8b149..1b3a9bb11f0 100644 --- a/hotspot/src/share/vm/utilities/bitMap.inline.hpp +++ b/hotspot/src/share/vm/utilities/bitMap.inline.hpp @@ -367,8 +367,4 @@ inline void BitMap2D::at_put_grow(idx_t slot_index, idx_t bit_within_slot_index, _map.at_put(bit, value); } -inline void BitMap2D::clear() { - _map.clear(); -} - #endif // SHARE_VM_UTILITIES_BITMAP_INLINE_HPP From 09caec497d8a0a71e29a59cc6ae76c20a9c47eea Mon Sep 17 00:00:00 2001 From: Stefan Johansson Date: Wed, 8 Jun 2016 16:29:12 +0200 Subject: [PATCH 037/125] 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB Reviewed-by: ehelin, mgerdin --- .../src/share/vm/gc/shared/threadLocalAllocBuffer.hpp | 1 + hotspot/src/share/vm/runtime/thread.inline.hpp | 9 ++++++--- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp b/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp index 6a5ab498bf6..1ee892e8469 100644 --- a/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp +++ b/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp @@ -110,6 +110,7 @@ public: static const size_t min_size() { return align_object_size(MinTLABSize / HeapWordSize) + alignment_reserve(); } static const size_t max_size() { assert(_max_size != 0, "max_size not set up"); return _max_size; } + static const size_t max_size_in_bytes() { return max_size() * BytesPerWord; } static void set_max_size(size_t max_size) { _max_size = max_size; } HeapWord* start() const { return _start; } diff --git a/hotspot/src/share/vm/runtime/thread.inline.hpp b/hotspot/src/share/vm/runtime/thread.inline.hpp index 4510bf2695f..b8c7a142612 100644 --- a/hotspot/src/share/vm/runtime/thread.inline.hpp +++ b/hotspot/src/share/vm/runtime/thread.inline.hpp @@ -71,9 +71,12 @@ inline jlong Thread::cooked_allocated_bytes() { jlong allocated_bytes = OrderAccess::load_acquire(&_allocated_bytes); if (UseTLAB) { size_t used_bytes = tlab().used_bytes(); - if ((ssize_t)used_bytes > 0) { - // More-or-less valid tlab. The load_acquire above should ensure - // that the result of the add is <= the instantaneous value. + if (used_bytes <= ThreadLocalAllocBuffer::max_size_in_bytes()) { + // Comparing used_bytes with the maximum allowed size will ensure + // that we don't add the used bytes from a semi-initialized TLAB + // ending up with incorrect values. There is still a race between + // incrementing _allocated_bytes and clearing the TLAB, that might + // cause double counting in rare cases. return allocated_bytes + used_bytes; } } From 27f9eddfc2ac0d313628f54a0d593a257e2eb913 Mon Sep 17 00:00:00 2001 From: Calvin Cheung Date: Wed, 8 Jun 2016 12:50:23 -0700 Subject: [PATCH 038/125] 8159019: ResourceMark in ClassLoader::open_versioned_entry() is being used incorrectly Call FREE_RESOURCE_ARRAY instead of declaring a ResourceMark Reviewed-by: hseigel, jiangli --- hotspot/src/share/vm/classfile/classLoader.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/classfile/classLoader.cpp b/hotspot/src/share/vm/classfile/classLoader.cpp index 265b485c7d9..1186067c242 100644 --- a/hotspot/src/share/vm/classfile/classLoader.cpp +++ b/hotspot/src/share/vm/classfile/classLoader.cpp @@ -380,7 +380,6 @@ u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TR if (is_multi_ver) { int n; - ResourceMark rm(THREAD); char* entry_name = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, JVM_MAXPATHLEN); if (version > 0) { n = jio_snprintf(entry_name, JVM_MAXPATHLEN, "META-INF/versions/%d/%s", version, name); @@ -400,6 +399,7 @@ u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TR } } } + FREE_RESOURCE_ARRAY(char, entry_name, JVM_MAXPATHLEN); } } return buffer; From 81ff3b7d935903483d01a643497000020d9da928 Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Wed, 8 Jun 2016 18:47:05 -0400 Subject: [PATCH 039/125] 8158681: ClassLoader::classloader_type() is called from code not included under #if INCLUDE_CDS Place CDS related code under #if INCLUDE_CDS. Reviewed-by: lfoltan, gtriantafill, coleenp --- hotspot/src/share/vm/classfile/classLoaderExt.hpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/hotspot/src/share/vm/classfile/classLoaderExt.hpp b/hotspot/src/share/vm/classfile/classLoaderExt.hpp index 24426d10552..6ce2275cc3b 100644 --- a/hotspot/src/share/vm/classfile/classLoaderExt.hpp +++ b/hotspot/src/share/vm/classfile/classLoaderExt.hpp @@ -54,12 +54,14 @@ public: const s2 classpath_index, instanceKlassHandle result, TRAPS) { if (ClassLoader::add_package(_file_name, classpath_index, THREAD)) { +#if INCLUDE_CDS if (DumpSharedSpaces) { s2 classloader_type = ClassLoader::classloader_type( class_name, e, classpath_index, CHECK_(result)); result->set_shared_classpath_index(classpath_index); result->set_class_loader_type(classloader_type); } +#endif return result; } else { return instanceKlassHandle(); // NULL From ec6f427ecc084cbf694688a9993592fae404783e Mon Sep 17 00:00:00 2001 From: Stefan Johansson Date: Thu, 9 Jun 2016 13:24:44 +0200 Subject: [PATCH 040/125] 8146530: [testbug] some tests fail because the compiler is using Java heap memory Reviewed-by: jwilhelm, jmasa, kvn --- hotspot/test/gc/arguments/TestTargetSurvivorRatioFlag.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/hotspot/test/gc/arguments/TestTargetSurvivorRatioFlag.java b/hotspot/test/gc/arguments/TestTargetSurvivorRatioFlag.java index aadb620ef9d..e2df1d7e866 100644 --- a/hotspot/test/gc/arguments/TestTargetSurvivorRatioFlag.java +++ b/hotspot/test/gc/arguments/TestTargetSurvivorRatioFlag.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,6 +25,8 @@ * @test TestTargetSurvivorRatioFlag * @key gc * @summary Verify that option TargetSurvivorRatio affects survivor space occupancy after minor GC. + * @requires (vm.opt.ExplicitGCInvokesConcurrent == null) | (vm.opt.ExplicitGCInvokesConcurrent == false) + * @requires (vm.opt.UseJVMCICompiler == null) | (vm.opt.UseJVMCICompiler == false) * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc * java.management From aa9857b6e245f97c2ffabac47d4168f314b1fe3d Mon Sep 17 00:00:00 2001 From: Stefan Johansson Date: Wed, 8 Jun 2016 16:26:11 +0200 Subject: [PATCH 041/125] 8157243: JMap heap test fail when used with external heap Reviewed-by: dsamersoff, ehelin --- .../sun/jvm/hotspot/memory/Universe.java | 4 ++- .../sun/jvm/hotspot/memory/UniverseExt.java | 31 +++++++++++++++++++ 2 files changed, 34 insertions(+), 1 deletion(-) create mode 100644 hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/UniverseExt.java diff --git a/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/Universe.java b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/Universe.java index f26fc452c94..637bdc5ecd5 100644 --- a/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/Universe.java +++ b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/Universe.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -96,6 +96,8 @@ public class Universe { narrowOopShiftField = type.getCIntegerField("_narrow_oop._shift"); narrowKlassBaseField = type.getAddressField("_narrow_klass._base"); narrowKlassShiftField = type.getCIntegerField("_narrow_klass._shift"); + + UniverseExt.initialize(heapConstructor); } public Universe() { diff --git a/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/UniverseExt.java b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/UniverseExt.java new file mode 100644 index 00000000000..54734c31736 --- /dev/null +++ b/hotspot/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/memory/UniverseExt.java @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +package sun.jvm.hotspot.memory; + +import sun.jvm.hotspot.runtime.*; + +public class UniverseExt { + public static void initialize(VirtualConstructor heapConstructor) { } +} From 84cab6c56f4eab4ed16b9f8bfeb72cab6631b3a8 Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Thu, 9 Jun 2016 16:52:32 +0300 Subject: [PATCH 042/125] 8156032: Clean up parallel GC specific code from vm/gc/shared/preservedMarks.cpp Reviewed-by: stefank, tschatzl --- .../src/share/vm/gc/g1/g1CollectedHeap.cpp | 3 +- .../vm/gc/parallel/psPromotionManager.cpp | 48 ++++++++++- .../share/vm/gc/serial/defNewGeneration.cpp | 3 +- .../src/share/vm/gc/shared/preservedMarks.cpp | 80 ++++++------------- .../src/share/vm/gc/shared/preservedMarks.hpp | 41 ++++++---- .../vm/gc/shared/preservedMarks.inline.hpp | 15 +--- 6 files changed, 101 insertions(+), 89 deletions(-) diff --git a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp index 90a7d35c144..de81be328d3 100644 --- a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp +++ b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp @@ -3474,7 +3474,8 @@ void G1CollectedHeap::restore_after_evac_failure() { double remove_self_forwards_start = os::elapsedTime(); remove_self_forwarding_pointers(); - _preserved_marks_set.restore(workers()); + SharedRestorePreservedMarksTaskExecutor task_executor(workers()); + _preserved_marks_set.restore(&task_executor); g1_policy()->phase_times()->record_evac_fail_remove_self_forwards((os::elapsedTime() - remove_self_forwards_start) * 1000.0); } diff --git a/hotspot/src/share/vm/gc/parallel/psPromotionManager.cpp b/hotspot/src/share/vm/gc/parallel/psPromotionManager.cpp index bdd965bd5b6..5a4ce68e176 100644 --- a/hotspot/src/share/vm/gc/parallel/psPromotionManager.cpp +++ b/hotspot/src/share/vm/gc/parallel/psPromotionManager.cpp @@ -23,6 +23,7 @@ */ #include "precompiled.hpp" +#include "gc/parallel/gcTaskManager.hpp" #include "gc/parallel/mutableSpace.hpp" #include "gc/parallel/parallelScavengeHeap.hpp" #include "gc/parallel/psOldGen.hpp" @@ -237,8 +238,53 @@ void PSPromotionManager::register_preserved_marks(PreservedMarks* preserved_mark _preserved_marks = preserved_marks; } +class ParRestoreGCTask : public GCTask { +private: + const uint _id; + PreservedMarksSet* const _preserved_marks_set; + volatile size_t* const _total_size_addr; + +public: + virtual char* name() { + return (char*) "preserved mark restoration task"; + } + + virtual void do_it(GCTaskManager* manager, uint which){ + _preserved_marks_set->get(_id)->restore_and_increment(_total_size_addr); + } + + ParRestoreGCTask(uint id, + PreservedMarksSet* preserved_marks_set, + volatile size_t* total_size_addr) + : _id(id), + _preserved_marks_set(preserved_marks_set), + _total_size_addr(total_size_addr) { } +}; + +class PSRestorePreservedMarksTaskExecutor : public RestorePreservedMarksTaskExecutor { +private: + GCTaskManager* _gc_task_manager; + +public: + PSRestorePreservedMarksTaskExecutor(GCTaskManager* gc_task_manager) + : _gc_task_manager(gc_task_manager) { } + + void restore(PreservedMarksSet* preserved_marks_set, + volatile size_t* total_size_addr) { + // GCTask / GCTaskQueue are ResourceObjs + ResourceMark rm; + + GCTaskQueue* q = GCTaskQueue::create(); + for (uint i = 0; i < preserved_marks_set->num(); i += 1) { + q->enqueue(new ParRestoreGCTask(i, preserved_marks_set, total_size_addr)); + } + _gc_task_manager->execute_and_wait(q); + } +}; + void PSPromotionManager::restore_preserved_marks() { - _preserved_marks_set->restore(PSScavenge::gc_task_manager()); + PSRestorePreservedMarksTaskExecutor task_executor(PSScavenge::gc_task_manager()); + _preserved_marks_set->restore(&task_executor); } void PSPromotionManager::drain_stacks_depth(bool totally_drain) { diff --git a/hotspot/src/share/vm/gc/serial/defNewGeneration.cpp b/hotspot/src/share/vm/gc/serial/defNewGeneration.cpp index c8d3e0f3894..a10a9f18c62 100644 --- a/hotspot/src/share/vm/gc/serial/defNewGeneration.cpp +++ b/hotspot/src/share/vm/gc/serial/defNewGeneration.cpp @@ -739,7 +739,8 @@ void DefNewGeneration::remove_forwarding_pointers() { eden()->object_iterate(&rspc); from()->object_iterate(&rspc); - _preserved_marks_set.restore(GenCollectedHeap::heap()->workers()); + SharedRestorePreservedMarksTaskExecutor task_executor(GenCollectedHeap::heap()->workers()); + _preserved_marks_set.restore(&task_executor); } void DefNewGeneration::handle_promotion_failure(oop old) { diff --git a/hotspot/src/share/vm/gc/shared/preservedMarks.cpp b/hotspot/src/share/vm/gc/shared/preservedMarks.cpp index 9312c198483..5f7381efa65 100644 --- a/hotspot/src/share/vm/gc/shared/preservedMarks.cpp +++ b/hotspot/src/share/vm/gc/shared/preservedMarks.cpp @@ -28,9 +28,6 @@ #include "memory/allocation.inline.hpp" #include "memory/resourceArea.hpp" #include "utilities/macros.hpp" -#if INCLUDE_ALL_GCS -#include "gc/parallel/gcTaskManager.hpp" -#endif void PreservedMarks::restore() { while (!_stack.is_empty()) { @@ -40,6 +37,15 @@ void PreservedMarks::restore() { assert_empty(); } +void PreservedMarks::restore_and_increment(volatile size_t* const total_size_addr) { + const size_t stack_size = size(); + restore(); + // Only do the atomic add if the size is > 0. + if (stack_size > 0) { + Atomic::add(stack_size, total_size_addr); + } +} + #ifndef PRODUCT void PreservedMarks::assert_empty() { assert(_stack.is_empty(), "stack expected to be empty, size = "SIZE_FORMAT, @@ -82,13 +88,7 @@ public: virtual void work(uint worker_id) { uint task_id = 0; while (!_sub_tasks.is_task_claimed(/* reference */ task_id)) { - PreservedMarks* const preserved_marks = _preserved_marks_set->get(task_id); - const size_t size = preserved_marks->size(); - preserved_marks->restore(); - // Only do the atomic add if the size is > 0. - if (size > 0) { - Atomic::add(size, _total_size_addr); - } + _preserved_marks_set->get(task_id)->restore_and_increment(_total_size_addr); } _sub_tasks.all_tasks_completed(); } @@ -104,53 +104,6 @@ public: } }; -void PreservedMarksSet::restore_internal(WorkGang* workers, - volatile size_t* total_size_addr) { - assert(workers != NULL, "pre-condition"); - ParRestoreTask task(workers->active_workers(), this, total_size_addr); - workers->run_task(&task); -} - -#if INCLUDE_ALL_GCS -class ParRestoreGCTask : public GCTask { -private: - const uint _id; - PreservedMarksSet* const _preserved_marks_set; - volatile size_t* const _total_size_addr; - -public: - virtual char* name() { return (char*) "preserved mark restoration task"; } - - virtual void do_it(GCTaskManager* manager, uint which) { - PreservedMarks* const preserved_marks = _preserved_marks_set->get(_id); - const size_t size = preserved_marks->size(); - preserved_marks->restore(); - // Only do the atomic add if the size is > 0. - if (size > 0) { - Atomic::add(size, _total_size_addr); - } - } - - ParRestoreGCTask(uint id, - PreservedMarksSet* preserved_marks_set, - volatile size_t* total_size_addr) - : _id(id), - _preserved_marks_set(preserved_marks_set), - _total_size_addr(total_size_addr) { } -}; - -void PreservedMarksSet::restore_internal(GCTaskManager* gc_task_manager, - volatile size_t* total_size_addr) { - // GCTask / GCTaskQueue are ResourceObjs - ResourceMark rm; - - GCTaskQueue* q = GCTaskQueue::create(); - for (uint i = 0; i < num(); i += 1) { - q->enqueue(new ParRestoreGCTask(i, this, total_size_addr)); - } - gc_task_manager->execute_and_wait(q); -} -#endif void PreservedMarksSet::reclaim() { assert_empty(); @@ -176,3 +129,16 @@ void PreservedMarksSet::assert_empty() { } } #endif // ndef PRODUCT + +void SharedRestorePreservedMarksTaskExecutor::restore(PreservedMarksSet* preserved_marks_set, + volatile size_t* total_size_addr) { + if (_workers == NULL) { + for (uint i = 0; i < preserved_marks_set->num(); i += 1) { + total_size_addr += preserved_marks_set->get(i)->size(); + preserved_marks_set->get(i)->restore(); + } + } else { + ParRestoreTask task(_workers->active_workers(), preserved_marks_set, total_size_addr); + _workers->run_task(&task); + } +} diff --git a/hotspot/src/share/vm/gc/shared/preservedMarks.hpp b/hotspot/src/share/vm/gc/shared/preservedMarks.hpp index 3c8ebd87cab..29fe7af25f7 100644 --- a/hotspot/src/share/vm/gc/shared/preservedMarks.hpp +++ b/hotspot/src/share/vm/gc/shared/preservedMarks.hpp @@ -30,7 +30,7 @@ #include "oops/oop.hpp" #include "utilities/stack.hpp" -class GCTaskManager; +class PreservedMarksSet; class WorkGang; class PreservedMarks VALUE_OBJ_CLASS_SPEC { @@ -61,6 +61,7 @@ public: // reclaim the memory taken up by the stack segments. void restore(); + void restore_and_increment(volatile size_t* const _total_size_addr); inline static void init_forwarded_mark(oop obj); // Assert the stack is empty and has no cached segments. @@ -75,6 +76,24 @@ public: virtual void do_object(oop obj); }; +class RestorePreservedMarksTaskExecutor { +public: + void virtual restore(PreservedMarksSet* preserved_marks_set, + volatile size_t* total_size_addr) = 0; +}; + +class SharedRestorePreservedMarksTaskExecutor : public RestorePreservedMarksTaskExecutor { +private: + WorkGang* _workers; + +public: + SharedRestorePreservedMarksTaskExecutor(WorkGang* workers) : _workers(workers) { } + + void restore(PreservedMarksSet* preserved_marks_set, + volatile size_t* total_size_addr); + +}; + class PreservedMarksSet : public CHeapObj { private: // true -> _stacks will be allocated in the C heap @@ -91,13 +110,6 @@ private: // or == NULL if they have not. Padded* _stacks; - // Internal version of restore() that uses a WorkGang for parallelism. - void restore_internal(WorkGang* workers, volatile size_t* total_size_addr); - - // Internal version of restore() that uses a GCTaskManager for parallelism. - void restore_internal(GCTaskManager* gc_task_manager, - volatile size_t* total_size_addr); - public: uint num() const { return _num; } @@ -111,14 +123,11 @@ public: // Allocate stack array. void init(uint num); - // Itrerate over all stacks, restore all presered marks, and reclaim - // the memory taken up by the stack segments. If the executor is - // NULL, restoration will be done serially. If the executor is not - // NULL, restoration could be done in parallel (when it makes - // sense). Supported executors: WorkGang (Serial, CMS, G1), - // GCTaskManager (PS). - template - inline void restore(E* executor); + // Iterate over all stacks, restore all preserved marks, and reclaim + // the memory taken up by the stack segments. + // Supported executors: SharedRestorePreservedMarksTaskExecutor (Serial, CMS, G1), + // PSRestorePreservedMarksTaskExecutor (PS). + inline void restore(RestorePreservedMarksTaskExecutor* executor); // Reclaim stack array. void reclaim(); diff --git a/hotspot/src/share/vm/gc/shared/preservedMarks.inline.hpp b/hotspot/src/share/vm/gc/shared/preservedMarks.inline.hpp index fc1039ad40b..7ed933002d8 100644 --- a/hotspot/src/share/vm/gc/shared/preservedMarks.inline.hpp +++ b/hotspot/src/share/vm/gc/shared/preservedMarks.inline.hpp @@ -49,8 +49,7 @@ inline void PreservedMarks::init_forwarded_mark(oop obj) { obj->init_mark(); } -template -inline void PreservedMarksSet::restore(E* executor) { +inline void PreservedMarksSet::restore(RestorePreservedMarksTaskExecutor* executor) { volatile size_t total_size = 0; #ifdef ASSERT @@ -61,17 +60,7 @@ inline void PreservedMarksSet::restore(E* executor) { } #endif // def ASSERT - if (executor == NULL) { - for (uint i = 0; i < _num; i += 1) { - total_size += get(i)->size(); - get(i)->restore(); - } - } else { - // Right now, if the executor is not NULL we do the work in - // parallel. In the future we might want to do the restoration - // serially, if there's only a small number of marks per stack. - restore_internal(executor, &total_size); - } + executor->restore(this, &total_size); assert_empty(); assert(total_size == total_size_before, From 59e58442196a75e81c67c50d1b92172e72581c70 Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Wed, 8 Jun 2016 16:07:49 +0200 Subject: [PATCH 043/125] 8159056: [aix] Compressed class space not allocated in lower regions Reviewed-by: dholmes, enevill --- hotspot/src/share/vm/memory/metaspace.cpp | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/hotspot/src/share/vm/memory/metaspace.cpp b/hotspot/src/share/vm/memory/metaspace.cpp index aa04201ad2e..a87292241b1 100644 --- a/hotspot/src/share/vm/memory/metaspace.cpp +++ b/hotspot/src/share/vm/memory/metaspace.cpp @@ -2933,7 +2933,7 @@ void Metaspace::allocate_metaspace_compressed_klass_ptrs(char* requested_addr, a // Don't use large pages for the class space. bool large_pages = false; -#ifndef AARCH64 +#if !(defined(AARCH64) || defined(AIX)) ReservedSpace metaspace_rs = ReservedSpace(compressed_class_space_size(), _reserve_alignment, large_pages, @@ -2945,18 +2945,25 @@ void Metaspace::allocate_metaspace_compressed_klass_ptrs(char* requested_addr, a // bits. if ((uint64_t)requested_addr + compressed_class_space_size() < 4*G) { metaspace_rs = ReservedSpace(compressed_class_space_size(), - _reserve_alignment, - large_pages, - requested_addr); + _reserve_alignment, + large_pages, + requested_addr); } if (! metaspace_rs.is_reserved()) { - // Try to align metaspace so that we can decode a compressed klass - // with a single MOVK instruction. We can do this iff the + // Aarch64: Try to align metaspace so that we can decode a compressed + // klass with a single MOVK instruction. We can do this iff the // compressed class base is a multiple of 4G. - for (char *a = (char*)align_ptr_up(requested_addr, 4*G); + // Aix: Search for a place where we can find memory. If we need to load + // the base, 4G alignment is helpful, too. + size_t increment = AARCH64_ONLY(4*)G; + for (char *a = (char*)align_ptr_up(requested_addr, increment); a < (char*)(1024*G); - a += 4*G) { + a += increment) { + if (a == (char *)(32*G)) { + // Go faster from here on. Zero-based is no longer possible. + increment = 4*G; + } #if INCLUDE_CDS if (UseSharedSpaces From 62a2685b4b07dca639d35e499b458d0e192c4dee Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Fri, 10 Jun 2016 02:43:53 +0000 Subject: [PATCH 044/125] 8158351: [JVMCI] NoClassDefFoundError: jdk/vm/ci/runtime/JVMCI Reviewed-by: kvn, vlivanov --- .../jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java index d1ed7a11737..20177c3de6c 100644 --- a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java +++ b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java @@ -27,7 +27,8 @@ * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") * @library / /testlibrary * @library ../common/patches - * @modules java.base/jdk.internal.org.objectweb.asm + * @modules java.base/jdk.internal.misc + java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code From d019f340778f5513b705ae4533b1156dd339be12 Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Fri, 10 Jun 2016 14:06:36 +0200 Subject: [PATCH 045/125] 8159237: PreservedMarks verification code fails Reviewed-by: lmesnik, jwilhelm --- hotspot/src/share/vm/gc/shared/preservedMarks.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/preservedMarks.cpp b/hotspot/src/share/vm/gc/shared/preservedMarks.cpp index 5f7381efa65..7a1078ebb34 100644 --- a/hotspot/src/share/vm/gc/shared/preservedMarks.cpp +++ b/hotspot/src/share/vm/gc/shared/preservedMarks.cpp @@ -131,10 +131,10 @@ void PreservedMarksSet::assert_empty() { #endif // ndef PRODUCT void SharedRestorePreservedMarksTaskExecutor::restore(PreservedMarksSet* preserved_marks_set, - volatile size_t* total_size_addr) { + volatile size_t* total_size_addr) { if (_workers == NULL) { for (uint i = 0; i < preserved_marks_set->num(); i += 1) { - total_size_addr += preserved_marks_set->get(i)->size(); + *total_size_addr += preserved_marks_set->get(i)->size(); preserved_marks_set->get(i)->restore(); } } else { From 35ba62637ef1a831486ff414eae52b8ab1f7c763 Mon Sep 17 00:00:00 2001 From: Jon Masamitsu Date: Fri, 10 Jun 2016 09:22:09 -0700 Subject: [PATCH 046/125] 8026752: Cancel MetaspaceGC request for a CMS concurrent collection after GC Reviewed-by: sjohanss, sangheki --- .../gc/cms/concurrentMarkSweepGeneration.cpp | 3 + hotspot/src/share/vm/prims/whitebox.cpp | 5 ++ .../gc/metaspace/TestMetaspaceCMSCancel.java | 70 +++++++++++++++++++ 3 files changed, 78 insertions(+) create mode 100644 hotspot/test/gc/metaspace/TestMetaspaceCMSCancel.java diff --git a/hotspot/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp b/hotspot/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp index bf11ad86915..1df96bd5826 100644 --- a/hotspot/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp +++ b/hotspot/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp @@ -1605,6 +1605,9 @@ void CMSCollector::do_compaction_work(bool clear_all_soft_refs) { _inter_sweep_timer.reset(); _inter_sweep_timer.start(); + // No longer a need to do a concurrent collection for Metaspace. + MetaspaceGC::set_should_concurrent_collect(false); + gch->post_full_gc_dump(gc_timer); gc_timer->register_gc_end(); diff --git a/hotspot/src/share/vm/prims/whitebox.cpp b/hotspot/src/share/vm/prims/whitebox.cpp index a55fd6340c6..e1a83af6739 100644 --- a/hotspot/src/share/vm/prims/whitebox.cpp +++ b/hotspot/src/share/vm/prims/whitebox.cpp @@ -1433,6 +1433,10 @@ WB_ENTRY(jlong, WB_MetaspaceCapacityUntilGC(JNIEnv* env, jobject wb)) return (jlong) MetaspaceGC::capacity_until_GC(); WB_END +WB_ENTRY(jboolean, WB_MetaspaceShouldConcurrentCollect(JNIEnv* env, jobject wb)) + return MetaspaceGC::should_concurrent_collect(); +WB_END + WB_ENTRY(void, WB_AssertMatchingSafepointCalls(JNIEnv* env, jobject o, jboolean mutexSafepointValue, jboolean attemptedNoSafepointValue)) Monitor::SafepointCheckRequired sfpt_check_required = mutexSafepointValue ? @@ -1813,6 +1817,7 @@ static JNINativeMethod methods[] = { CC"(Ljava/lang/ClassLoader;JJ)V", (void*)&WB_FreeMetaspace }, {CC"incMetaspaceCapacityUntilGC", CC"(J)J", (void*)&WB_IncMetaspaceCapacityUntilGC }, {CC"metaspaceCapacityUntilGC", CC"()J", (void*)&WB_MetaspaceCapacityUntilGC }, + {CC"metaspaceShouldConcurrentCollect", CC"()Z", (void*)&WB_MetaspaceShouldConcurrentCollect }, {CC"getCPUFeatures", CC"()Ljava/lang/String;", (void*)&WB_GetCPUFeatures }, {CC"getNMethod0", CC"(Ljava/lang/reflect/Executable;Z)[Ljava/lang/Object;", (void*)&WB_GetNMethod }, diff --git a/hotspot/test/gc/metaspace/TestMetaspaceCMSCancel.java b/hotspot/test/gc/metaspace/TestMetaspaceCMSCancel.java new file mode 100644 index 00000000000..42357ff03dd --- /dev/null +++ b/hotspot/test/gc/metaspace/TestMetaspaceCMSCancel.java @@ -0,0 +1,70 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +import jdk.test.lib.process.ProcessTools; +import jdk.test.lib.process.OutputAnalyzer; +import jdk.test.lib.Asserts; +import sun.hotspot.WhiteBox; + +/* @test TestMetaspaceCMSCancel + * @bug 8026752 + * @summary Tests cancel of CMS concurrent cycle for Metaspace after a full GC + * @library /testlibrary /test/lib /test/lib/share/classes + * @modules java.base/jdk.internal.misc + * @build TestMetaspaceCMSCancel + * @run main ClassFileInstaller sun.hotspot.WhiteBox + * @run main/othervm TestMetaspaceCMSCancel + */ + + +public class TestMetaspaceCMSCancel { + + public static void main(String[] args) throws Exception { + // Set a small MetaspaceSize so that a CMS concurrent collection will be + // scheduled. Set CMSWaitDuration to 5s so that the concurrent collection + // start may be delayed. It does not guarantee 5s before the start of the + // concurrent collection but does increase the probability that it will + // be started later. System.gc() is used to invoke a full collection. Set + // ExplicitGCInvokesConcurrent to off so it is a STW collection. + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xbootclasspath/a:.", + "-XX:+UnlockDiagnosticVMOptions", + "-XX:+WhiteBoxAPI", + "-XX:+UseConcMarkSweepGC", + "-XX:MetaspaceSize=2m", + "-XX:CMSWaitDuration=5000", + "-XX:-ExplicitGCInvokesConcurrent", + "-Xlog:gc*=debug", + MetaspaceGCTest.class.getName()); + + OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldNotContain("Concurrent Reset"); + output.shouldHaveExitValue(0); + } + + static class MetaspaceGCTest { + public static void main(String [] args) { + WhiteBox wb = WhiteBox.getWhiteBox(); + System.gc(); + Asserts.assertFalse(wb.metaspaceShouldConcurrentCollect()); + } + } +} From 08962e6714b7f50d44aaa57ca219cae2488a80ec Mon Sep 17 00:00:00 2001 From: Jon Masamitsu Date: Thu, 19 May 2016 14:53:18 -0700 Subject: [PATCH 047/125] 8157373: Active workers should not be reset in AbstractWorkGang initialize() Reviewed-by: kbarrett, tschatzl, jwilhelm --- hotspot/src/share/vm/gc/shared/workgroup.cpp | 5 ----- 1 file changed, 5 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/workgroup.cpp b/hotspot/src/share/vm/gc/shared/workgroup.cpp index f53285d9b26..053c8a1b8cf 100644 --- a/hotspot/src/share/vm/gc/shared/workgroup.cpp +++ b/hotspot/src/share/vm/gc/shared/workgroup.cpp @@ -44,11 +44,6 @@ void AbstractWorkGang::initialize_workers() { vm_exit_out_of_memory(0, OOM_MALLOC_ERROR, "Cannot create GangWorker array."); } - _active_workers = ParallelGCThreads; - if (UseDynamicNumberOfGCThreads && !FLAG_IS_CMDLINE(ParallelGCThreads)) { - _active_workers = 1U; - } - add_workers(true); } From de17002b7c423d938b35521516146cc1b3585f54 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Mon, 6 Jun 2016 16:18:01 -0700 Subject: [PATCH 048/125] 8156587: [JVMCI] remove Unsafe.getJavaMirror and Unsafe.getKlassPointer Reviewed-by: kvn --- .../classes/jdk/internal/misc/Unsafe.java | 18 ------------------ 1 file changed, 18 deletions(-) diff --git a/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java b/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java index f4e11a3378a..77bdf2db106 100644 --- a/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java +++ b/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java @@ -318,24 +318,6 @@ public final class Unsafe { */ public native Object getUncompressedObject(long address); - /** - * Fetches the {@link java.lang.Class} Java mirror for the given native - * metaspace {@code Klass} pointer. - * - * @param metaspaceKlass a native metaspace {@code Klass} pointer - * @return the {@link java.lang.Class} Java mirror - */ - public native Class getJavaMirror(long metaspaceKlass); - - /** - * Fetches a native metaspace {@code Klass} pointer for the given Java - * object. - * - * @param o Java heap object for which to fetch the class pointer - * @return a native metaspace {@code Klass} pointer - */ - public native long getKlassPointer(Object o); - // These work on values in the C heap. /** From d3ebf81e39f68d5945f00a9ff53df2b25762b2ad Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Tue, 7 Jun 2016 12:55:09 +0300 Subject: [PATCH 049/125] 8154209: Remove client VM from default JIB profile on windows-x86 and linux-x86 Reviewed-by: dholmes --- common/conf/jib-profiles.js | 5 ++--- make/jprt.properties | 8 ++++---- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/common/conf/jib-profiles.js b/common/conf/jib-profiles.js index 2d752fd1074..6eac8e428fa 100644 --- a/common/conf/jib-profiles.js +++ b/common/conf/jib-profiles.js @@ -254,7 +254,7 @@ var getJibProfilesProfiles = function (input, common) { build_cpu: "x64", dependencies: concat(common.dependencies, "devkit"), configure_args: concat(common.configure_args, common.configure_args_32bit, - "--with-jvm-variants=minimal,client,server", "--with-zlib=system"), + "--with-jvm-variants=minimal,server", "--with-zlib=system"), default_make_targets: common.default_make_targets }, @@ -295,8 +295,7 @@ var getJibProfilesProfiles = function (input, common) { target_cpu: "x86", build_cpu: "x64", dependencies: concat(common.dependencies, "devkit", "freetype"), - configure_args: concat(common.configure_args, - "--with-jvm-variants=client,server", common.configure_args_32bit), + configure_args: concat(common.configure_args, common.configure_args_32bit), default_make_targets: common.default_make_targets } }; diff --git a/make/jprt.properties b/make/jprt.properties index 93ccd1eb560..2130ae6b5db 100644 --- a/make/jprt.properties +++ b/make/jprt.properties @@ -75,7 +75,7 @@ jprt.windows.jdk9.target.attribute.compilerVS2013.appliesTo.builds=none jprt.macosx.jdk9.target.attribute.compilerXcode511.appliesTo.builds=none # Set up the run flavors (jvm variants) -jprt.run.flavors=c1,c2,default,${my.additional.run.flavors} +jprt.run.flavors=c2,default,${my.additional.run.flavors} # Setup jib profiles jprt.linux_i586.product.build.jib.profile=linux-x86 @@ -208,10 +208,10 @@ my.build.targets.default= \ my.test.target.set= \ solaris_sparcv9_5.11-product-c2-TESTNAME, \ solaris_x64_5.11-product-c2-TESTNAME, \ - linux_i586_3.8-product-{c1|c2}-TESTNAME, \ + linux_i586_3.8-product-c2-TESTNAME, \ linux_x64_3.8-product-c2-TESTNAME, \ macosx_x64_10.9-product-c2-TESTNAME, \ - windows_i586_6.3-product-c1-TESTNAME, \ + windows_i586_6.3-product-c2-TESTNAME, \ windows_x64_6.3-product-c2-TESTNAME # Default vm test targets (testset=default) @@ -296,7 +296,7 @@ my.make.rule.test.targets.pit= \ my.test.target.set.jck= \ solaris_sparcv9_5.11-product-c2-JCK7TESTRULE, \ solaris_x64_5.11-product-c2-JCK7TESTRULE, \ - linux_i586_3.8-product-c1-JCK7TESTRULE, \ + linux_i586_3.8-product-c2-JCK7TESTRULE, \ linux_x64_3.8-product-c2-JCK7TESTRULE # JCK testset targets From 008425f637e910bc833766a5a917d68f6b699573 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Tue, 7 Jun 2016 18:25:53 +0200 Subject: [PATCH 050/125] 8158938: AIX: some more new hotspot build fixes Reviewed-by: erikj --- common/autoconf/build-performance.m4 | 3 +++ common/autoconf/flags.m4 | 10 +++++----- common/autoconf/generated-configure.sh | 22 +++++++++++++--------- common/autoconf/hotspot.m4 | 2 +- 4 files changed, 22 insertions(+), 15 deletions(-) diff --git a/common/autoconf/build-performance.m4 b/common/autoconf/build-performance.m4 index 04944aec383..3987b7b4402 100644 --- a/common/autoconf/build-performance.m4 +++ b/common/autoconf/build-performance.m4 @@ -367,6 +367,9 @@ AC_DEFUN_ONCE([BPERF_SETUP_PRECOMPILED_HEADERS], elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then AC_MSG_RESULT([no, does not work with Solaris Studio]) USE_PRECOMPILED_HEADER=0 + elif test "x$TOOLCHAIN_TYPE" = xxlc; then + AC_MSG_RESULT([no, does not work with xlc]) + USE_PRECOMPILED_HEADER=0 else AC_MSG_RESULT([yes]) fi diff --git a/common/autoconf/flags.m4 b/common/autoconf/flags.m4 index bdcec6208f3..49013744d78 100644 --- a/common/autoconf/flags.m4 +++ b/common/autoconf/flags.m4 @@ -593,9 +593,9 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION], fi C_O_FLAG_NONE="-O0" elif test "x$TOOLCHAIN_TYPE" = xxlc; then - C_O_FLAG_HIGHEST_JVM="-O3" - C_O_FLAG_HIGHEST="-O3" - C_O_FLAG_HI="-O3 -qstrict" + C_O_FLAG_HIGHEST_JVM="-O3 -qhot=level=1 -qinline -qinlglue" + C_O_FLAG_HIGHEST="-O3 -qhot=level=1 -qinline -qinlglue" + C_O_FLAG_HI="-O3 -qinline -qinlglue" C_O_FLAG_NORM="-O2" C_O_FLAG_DEBUG="-qnoopt" # FIXME: Value below not verified. @@ -911,8 +911,8 @@ AC_DEFUN([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK_HELPER], elif test "x$OPENJDK_$1_OS" = xaix; then $2JVM_CFLAGS="[$]$2JVM_CFLAGS -DAIX" # We may need '-qminimaltoc' or '-qpic=large -bbigtoc' if the TOC overflows. - $2JVM_CFLAGS="[$]$2JVM_CFLAGS -qtune=balanced -qhot=level=1 -qinline \ - -qinlglue -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ + $2JVM_CFLAGS="[$]$2JVM_CFLAGS -qtune=balanced \ + -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ -qlanglvl=noredefmac -qnortti -qnoeh -qignerrno" elif test "x$OPENJDK_$1_OS" = xbsd; then $2COMMON_CCXXFLAGS_JDK="[$]$2COMMON_CCXXFLAGS_JDK -D_ALLBSD_SOURCE" diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index e4c2dab06f9..566a4873f43 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -5092,7 +5092,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1464173584 +DATE_WHEN_GENERATED=1465316678 ############################################################################### # @@ -49613,9 +49613,9 @@ $as_echo "$supports" >&6; } fi C_O_FLAG_NONE="-O0" elif test "x$TOOLCHAIN_TYPE" = xxlc; then - C_O_FLAG_HIGHEST_JVM="-O3" - C_O_FLAG_HIGHEST="-O3" - C_O_FLAG_HI="-O3 -qstrict" + C_O_FLAG_HIGHEST_JVM="-O3 -qhot=level=1 -qinline -qinlglue" + C_O_FLAG_HIGHEST="-O3 -qhot=level=1 -qinline -qinlglue" + C_O_FLAG_HI="-O3 -qinline -qinlglue" C_O_FLAG_NORM="-O2" C_O_FLAG_DEBUG="-qnoopt" # FIXME: Value below not verified. @@ -50622,8 +50622,8 @@ $as_echo "$supports" >&6; } elif test "x$OPENJDK_TARGET_OS" = xaix; then JVM_CFLAGS="$JVM_CFLAGS -DAIX" # We may need '-qminimaltoc' or '-qpic=large -bbigtoc' if the TOC overflows. - JVM_CFLAGS="$JVM_CFLAGS -qtune=balanced -qhot=level=1 -qinline \ - -qinlglue -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ + JVM_CFLAGS="$JVM_CFLAGS -qtune=balanced \ + -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ -qlanglvl=noredefmac -qnortti -qnoeh -qignerrno" elif test "x$OPENJDK_TARGET_OS" = xbsd; then COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS_JDK -D_ALLBSD_SOURCE" @@ -51427,8 +51427,8 @@ $as_echo "$supports" >&6; } elif test "x$OPENJDK_BUILD_OS" = xaix; then OPENJDK_BUILD_JVM_CFLAGS="$OPENJDK_BUILD_JVM_CFLAGS -DAIX" # We may need '-qminimaltoc' or '-qpic=large -bbigtoc' if the TOC overflows. - OPENJDK_BUILD_JVM_CFLAGS="$OPENJDK_BUILD_JVM_CFLAGS -qtune=balanced -qhot=level=1 -qinline \ - -qinlglue -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ + OPENJDK_BUILD_JVM_CFLAGS="$OPENJDK_BUILD_JVM_CFLAGS -qtune=balanced \ + -qalias=noansi -qstrict -qtls=default -qlanglvl=c99vla \ -qlanglvl=noredefmac -qnortti -qnoeh -qignerrno" elif test "x$OPENJDK_BUILD_OS" = xbsd; then OPENJDK_BUILD_COMMON_CCXXFLAGS_JDK="$OPENJDK_BUILD_COMMON_CCXXFLAGS_JDK -D_ALLBSD_SOURCE" @@ -53456,7 +53456,7 @@ $as_echo "yes, forced" >&6; } $as_echo "no, forced" >&6; } BUILD_GTEST="false" elif test "x$enable_hotspot_gtest" = "x"; then - if test "x$GTEST_DIR_EXISTS" = "xtrue"; then + if test "x$GTEST_DIR_EXISTS" = "xtrue" && test "x$OPENJDK_TARGET_OS" != "xaix"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } BUILD_GTEST="true" @@ -66120,6 +66120,10 @@ $as_echo "no, does not work effectively with icecc" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, does not work with Solaris Studio" >&5 $as_echo "no, does not work with Solaris Studio" >&6; } USE_PRECOMPILED_HEADER=0 + elif test "x$TOOLCHAIN_TYPE" = xxlc; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, does not work with xlc" >&5 +$as_echo "no, does not work with xlc" >&6; } + USE_PRECOMPILED_HEADER=0 else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } diff --git a/common/autoconf/hotspot.m4 b/common/autoconf/hotspot.m4 index 18b6ec0aa21..3886ea86f65 100644 --- a/common/autoconf/hotspot.m4 +++ b/common/autoconf/hotspot.m4 @@ -333,7 +333,7 @@ AC_DEFUN_ONCE([HOTSPOT_ENABLE_DISABLE_GTEST], AC_MSG_RESULT([no, forced]) BUILD_GTEST="false" elif test "x$enable_hotspot_gtest" = "x"; then - if test "x$GTEST_DIR_EXISTS" = "xtrue"; then + if test "x$GTEST_DIR_EXISTS" = "xtrue" && test "x$OPENJDK_TARGET_OS" != "xaix"; then AC_MSG_RESULT([yes]) BUILD_GTEST="true" else From cb2da4e3e760a61655debec5e07a23746d515b14 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Tue, 7 Jun 2016 22:01:49 -0400 Subject: [PATCH 051/125] 8158763: --disable-hotspot-gtest not working on Solaris Reviewed-by: dholmes --- common/autoconf/generated-configure.sh | 8 ++++++-- common/autoconf/libraries.m4 | 6 +++++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 566a4873f43..5371b8c1985 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -5092,7 +5092,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1465316678 +DATE_WHEN_GENERATED=1465351120 ############################################################################### # @@ -64600,12 +64600,16 @@ fi - if test "$OPENJDK_TARGET_OS" = "solaris"; then + if test "$OPENJDK_TARGET_OS" = "solaris" && test "x$BUILD_GTEST" = "xtrue"; then # Find the root of the Solaris Studio installation from the compiler path SOLARIS_STUDIO_DIR="$(dirname $CC)/.." STLPORT_LIB="$SOLARIS_STUDIO_DIR/lib/stlport4$OPENJDK_TARGET_CPU_ISADIR/libstlport.so.1" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for libstlport.so.1" >&5 $as_echo_n "checking for libstlport.so.1... " >&6; } + if ! test -f "$STLPORT_LIB" && test "x$OPENJDK_TARGET_CPU_ISADIR" = "x/sparcv9"; then + # SS12u3 has libstlport under 'stlport4/v9' instead of 'stlport4/sparcv9' + STLPORT_LIB="$SOLARIS_STUDIO_DIR/lib/stlport4/v9/libstlport.so.1" + fi if test -f "$STLPORT_LIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes, $STLPORT_LIB" >&5 $as_echo "yes, $STLPORT_LIB" >&6; } diff --git a/common/autoconf/libraries.m4 b/common/autoconf/libraries.m4 index 4238a17fe82..ce43d229dd7 100644 --- a/common/autoconf/libraries.m4 +++ b/common/autoconf/libraries.m4 @@ -197,11 +197,15 @@ AC_DEFUN_ONCE([LIB_SETUP_MISC_LIBS], ################################################################################ AC_DEFUN_ONCE([LIB_SETUP_SOLARIS_STLPORT], [ - if test "$OPENJDK_TARGET_OS" = "solaris"; then + if test "$OPENJDK_TARGET_OS" = "solaris" && test "x$BUILD_GTEST" = "xtrue"; then # Find the root of the Solaris Studio installation from the compiler path SOLARIS_STUDIO_DIR="$(dirname $CC)/.." STLPORT_LIB="$SOLARIS_STUDIO_DIR/lib/stlport4$OPENJDK_TARGET_CPU_ISADIR/libstlport.so.1" AC_MSG_CHECKING([for libstlport.so.1]) + if ! test -f "$STLPORT_LIB" && test "x$OPENJDK_TARGET_CPU_ISADIR" = "x/sparcv9"; then + # SS12u3 has libstlport under 'stlport4/v9' instead of 'stlport4/sparcv9' + STLPORT_LIB="$SOLARIS_STUDIO_DIR/lib/stlport4/v9/libstlport.so.1" + fi if test -f "$STLPORT_LIB"; then AC_MSG_RESULT([yes, $STLPORT_LIB]) BASIC_FIXUP_PATH([STLPORT_LIB]) From 19c8ab3cdbfa0e36e13b31b522a709099f58cefd Mon Sep 17 00:00:00 2001 From: Erik Helin Date: Wed, 8 Jun 2016 13:24:36 +0200 Subject: [PATCH 052/125] 8159045: Remove const from methods returning size_t in threadLocalAllocBuffer.hpp Reviewed-by: sjohanss, jmasa --- hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp b/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp index 1ee892e8469..5edda5a834f 100644 --- a/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp +++ b/hotspot/src/share/vm/gc/shared/threadLocalAllocBuffer.hpp @@ -108,9 +108,9 @@ public: // do nothing. tlabs must be inited by initialize() calls } - static const size_t min_size() { return align_object_size(MinTLABSize / HeapWordSize) + alignment_reserve(); } - static const size_t max_size() { assert(_max_size != 0, "max_size not set up"); return _max_size; } - static const size_t max_size_in_bytes() { return max_size() * BytesPerWord; } + static size_t min_size() { return align_object_size(MinTLABSize / HeapWordSize) + alignment_reserve(); } + static size_t max_size() { assert(_max_size != 0, "max_size not set up"); return _max_size; } + static size_t max_size_in_bytes() { return max_size() * BytesPerWord; } static void set_max_size(size_t max_size) { _max_size = max_size; } HeapWord* start() const { return _start; } From 8bb3799029d34e7f5bbc3d9e5bc6da7068360bc7 Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Thu, 9 Jun 2016 15:17:18 +0200 Subject: [PATCH 053/125] 8159156: [TESTBUG] ReserveMemory test is not useful on Aix Reviewed-by: dholmes --- hotspot/test/runtime/memory/ReserveMemory.java | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/hotspot/test/runtime/memory/ReserveMemory.java b/hotspot/test/runtime/memory/ReserveMemory.java index b6fadfd0bcf..c9d80302174 100644 --- a/hotspot/test/runtime/memory/ReserveMemory.java +++ b/hotspot/test/runtime/memory/ReserveMemory.java @@ -21,10 +21,12 @@ * questions. */ +// Aix commits on touch, so this test won't work. /* * @test * @key regression * @bug 8012015 + * @requires !(os.family == "aix") * @summary Make sure reserved (but uncommitted) memory is not accessible * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc @@ -36,18 +38,11 @@ */ import jdk.test.lib.*; +import jdk.test.lib.Platform; import sun.hotspot.WhiteBox; public class ReserveMemory { - private static boolean isWindows() { - return System.getProperty("os.name").toLowerCase().startsWith("win"); - } - - private static boolean isOsx() { - return System.getProperty("os.name").toLowerCase().startsWith("mac"); - } - public static void main(String args[]) throws Exception { if (args.length > 0) { WhiteBox.getWhiteBox().readReservedMemory(); @@ -66,9 +61,9 @@ public class ReserveMemory { "test"); OutputAnalyzer output = new OutputAnalyzer(pb.start()); - if (isWindows()) { + if (Platform.isWindows()) { output.shouldContain("EXCEPTION_ACCESS_VIOLATION"); - } else if (isOsx()) { + } else if (Platform.isOSX()) { output.shouldContain("SIGBUS"); } else { output.shouldContain("SIGSEGV"); From 0818ea7b6431b053c53ca428367a60a6c73582b0 Mon Sep 17 00:00:00 2001 From: Jon Masamitsu Date: Fri, 10 Jun 2016 11:40:02 -0700 Subject: [PATCH 054/125] 8026752: Cancel MetaspaceGC request for a CMS concurrent collection after GC Reviewed-by: sjohanss, sangheki --- test/lib/sun/hotspot/WhiteBox.java | 1 + 1 file changed, 1 insertion(+) diff --git a/test/lib/sun/hotspot/WhiteBox.java b/test/lib/sun/hotspot/WhiteBox.java index 690b07af0bd..7fd742b79c1 100644 --- a/test/lib/sun/hotspot/WhiteBox.java +++ b/test/lib/sun/hotspot/WhiteBox.java @@ -376,6 +376,7 @@ public class WhiteBox { public native void freeMetaspace(ClassLoader classLoader, long addr, long size); public native long incMetaspaceCapacityUntilGC(long increment); public native long metaspaceCapacityUntilGC(); + public native boolean metaspaceShouldConcurrentCollect(); // Force Young GC public native void youngGC(); From 6223e843f9e43bbd442fe74927628a5c8d7e1fdb Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Mon, 27 Jun 2016 13:57:24 -0700 Subject: [PATCH 055/125] 8160312: ArrayIndexOutOfBoundsException when comparing strings case insensitive Reviewed-by: rriggs --- jdk/src/java.base/share/classes/java/lang/StringLatin1.java | 4 ++-- jdk/test/java/lang/String/CompareIC.java | 6 +++++- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/StringLatin1.java b/jdk/src/java.base/share/classes/java/lang/StringLatin1.java index e4901dd69ad..b307bee6d46 100644 --- a/jdk/src/java.base/share/classes/java/lang/StringLatin1.java +++ b/jdk/src/java.base/share/classes/java/lang/StringLatin1.java @@ -137,8 +137,8 @@ final class StringLatin1 { char c1 = (char) CharacterDataLatin1.instance.toUpperCase(getChar(value, k)); char c2 = (char) CharacterDataLatin1.instance.toUpperCase(getChar(other, k)); if (c1 != c2) { - c1 = (char) CharacterDataLatin1.instance.toLowerCase(c1); - c2 = (char) CharacterDataLatin1.instance.toLowerCase(c2); + c1 = Character.toLowerCase(c1); + c2 = Character.toLowerCase(c2); if (c1 != c2) { return c1 - c2; } diff --git a/jdk/test/java/lang/String/CompareIC.java b/jdk/test/java/lang/String/CompareIC.java index da06ded3894..ebe3056c972 100644 --- a/jdk/test/java/lang/String/CompareIC.java +++ b/jdk/test/java/lang/String/CompareIC.java @@ -23,7 +23,7 @@ /* * @test - * @bug 4124769 + * @bug 4124769 8160312 * @summary Test ignore-case comparison * */ @@ -45,6 +45,10 @@ public class CompareIC { comparer.testTriplet(test1, test2, test3); test2 = test2.toLowerCase(); comparer.testTriplet(test1, test2, test3); + + // toLowerCase -> non-latin1 + if ("\u00b5".compareToIgnoreCase("X") < 0) + throw new RuntimeException("Comparison failure1"); } private void testTriplet(String one, String two, String three) From a2ed88900265042ea00d534988fa21edca857e3d Mon Sep 17 00:00:00 2001 From: Claes Redestad Date: Tue, 28 Jun 2016 00:39:26 +0200 Subject: [PATCH 056/125] 8160000: Runtime.version() cause startup regressions in 9+119 Reviewed-by: mchung, psandoz, erikj, forax, iris --- jdk/make/gensrc/GensrcMisc.gmk | 6 +- .../share/classes/java/lang/Runtime.java | 179 +++++++++--------- .../java/lang/VersionProps.java.template | 55 +++++- 3 files changed, 151 insertions(+), 89 deletions(-) diff --git a/jdk/make/gensrc/GensrcMisc.gmk b/jdk/make/gensrc/GensrcMisc.gmk index 0ce43ff4f8d..475b8f1d033 100644 --- a/jdk/make/gensrc/GensrcMisc.gmk +++ b/jdk/make/gensrc/GensrcMisc.gmk @@ -34,7 +34,11 @@ $(eval $(call SetupTextFileProcessing, BUILD_VERSION_JAVA, \ @@LAUNCHER_NAME@@ => $(LAUNCHER_NAME) ; \ @@RUNTIME_NAME@@ => $(RUNTIME_NAME) ; \ @@VERSION_SHORT@@ => $(VERSION_SHORT) ; \ - @@VERSION_STRING@@ => $(VERSION_STRING), \ + @@VERSION_STRING@@ => $(VERSION_STRING) ; \ + @@VERSION_NUMBER@@ => $(VERSION_NUMBER) ; \ + @@VERSION_PRE@@ => $(VERSION_PRE) ; \ + @@VERSION_BUILD@@ => $(VERSION_BUILD) ; \ + @@VERSION_OPT@@ => $(VERSION_OPT), \ )) GENSRC_JAVA_BASE += $(BUILD_VERSION_JAVA) diff --git a/jdk/src/java.base/share/classes/java/lang/Runtime.java b/jdk/src/java.base/share/classes/java/lang/Runtime.java index 1533130017b..fd5cb88a7d6 100644 --- a/jdk/src/java.base/share/classes/java/lang/Runtime.java +++ b/jdk/src/java.base/share/classes/java/lang/Runtime.java @@ -27,8 +27,6 @@ package java.lang; import java.io.*; import java.math.BigInteger; -import java.util.AbstractList; -import java.util.Arrays; import java.util.ArrayList; import java.util.regex.Matcher; import java.util.regex.Pattern; @@ -36,11 +34,9 @@ import java.util.stream.Collectors; import java.util.Collections; import java.util.List; import java.util.Optional; -import java.util.RandomAccess; import java.util.StringTokenizer; import jdk.internal.reflect.CallerSensitive; import jdk.internal.reflect.Reflection; -import sun.security.action.GetPropertyAction; /** * Every Java application has a single instance of class @@ -941,8 +937,9 @@ public class Runtime { */ public static Version version() { if (version == null) { - version = Version.parse( - GetPropertyAction.privilegedGetProperty("java.runtime.version")); + version = new Version(VersionProps.versionNumbers(), + VersionProps.pre(), VersionProps.build(), + VersionProps.optional()); } return version; } @@ -1084,86 +1081,12 @@ public class Runtime { private final Optional build; private final Optional optional; - - // $VNUM(-$PRE)?(\+($BUILD)?(\-$OPT)?)? - // RE limits the format of version strings - // ([1-9][0-9]*(?:(?:\.0)*\.[1-9][0-9]*)*)(?:-([a-zA-Z0-9]+))?(?:(\+)(0|[1-9][0-9]*)?)?(?:-([-a-zA-Z0-9.]+))? - - private static final String VNUM - = "(?[1-9][0-9]*(?:(?:\\.0)*\\.[1-9][0-9]*)*)"; - private static final String VNUM_GROUP = "VNUM"; - - private static final String PRE = "(?:-(?
[a-zA-Z0-9]+))?";
-        private static final String PRE_GROUP   = "PRE";
-
-        private static final String BUILD
-            = "(?:(?\\+)(?0|[1-9][0-9]*)?)?";
-        private static final String PLUS_GROUP  = "PLUS";
-        private static final String BUILD_GROUP = "BUILD";
-
-        private static final String OPT      = "(?:-(?[-a-zA-Z0-9.]+))?";
-        private static final String OPT_GROUP   = "OPT";
-
-        private static final String VSTR_FORMAT
-            = "^" + VNUM + PRE + BUILD + OPT + "$";
-        private static final Pattern VSTR_PATTERN = Pattern.compile(VSTR_FORMAT);
-
-        /**
-         * Constructs a valid version string containing
-         * a version number followed by pre-release and
-         * build information.
-         *
-         * @param  s
-         *         A string to be interpreted as a version
-         *
-         * @throws  IllegalArgumentException
-         *          If the given string cannot be interpreted as a valid
-         *          version
-         *
-         * @throws  NullPointerException
-         *          If {@code s} is {@code null}
-         *
-         * @throws  NumberFormatException
-         *          If an element of the version number or the build number
-         *          cannot be represented as an {@link Integer}
-         */
-        private Version(String s) {
-            if (s == null)
-                throw new NullPointerException();
-
-            Matcher m = VSTR_PATTERN.matcher(s);
-            if (!m.matches())
-                throw new IllegalArgumentException("Invalid version string: '"
-                                                   + s + "'");
-
-            // $VNUM is a dot-separated list of integers of arbitrary length
-            List list = new ArrayList<>();
-            for (String i : m.group(VNUM_GROUP).split("\\."))
-                list.add(Integer.parseInt(i));
-            version = Collections.unmodifiableList(list);
-
-            pre = Optional.ofNullable(m.group(PRE_GROUP));
-
-            String b = m.group(BUILD_GROUP);
-            // $BUILD is an integer
-            build = (b == null)
-                ? Optional.empty()
-                : Optional.ofNullable(Integer.parseInt(b));
-
-            optional = Optional.ofNullable(m.group(OPT_GROUP));
-
-            // empty '+'
-            if ((m.group(PLUS_GROUP) != null) && !build.isPresent()) {
-                if (optional.isPresent()) {
-                    if (pre.isPresent())
-                        throw new IllegalArgumentException("'+' found with"
-                            + " pre-release and optional components:'" + s
-                            + "'");
-                } else {
-                    throw new IllegalArgumentException("'+' found with neither"
-                        + " build or optional components: '" + s + "'");
-                }
-            }
+        Version(List version, Optional pre,
+                Optional build, Optional optional) {
+            this.version = Collections.unmodifiableList(version);
+            this.pre = pre;
+            this.build = build;
+            this.optional = optional;
         }
 
         /**
@@ -1189,7 +1112,7 @@ public class Runtime {
          * @return  The Version of the given string
          */
         public static Version parse(String s) {
-            return new Version(s);
+            return VersionBuilder.parse(s);
         }
 
         /**
@@ -1518,4 +1441,86 @@ public class Runtime {
         }
     }
 
+    private static class VersionBuilder {
+        // $VNUM(-$PRE)?(\+($BUILD)?(\-$OPT)?)?
+        // RE limits the format of version strings
+        // ([1-9][0-9]*(?:(?:\.0)*\.[1-9][0-9]*)*)(?:-([a-zA-Z0-9]+))?(?:(\+)(0|[1-9][0-9]*)?)?(?:-([-a-zA-Z0-9.]+))?
+
+        private static final String VNUM
+            = "(?[1-9][0-9]*(?:(?:\\.0)*\\.[1-9][0-9]*)*)";
+        private static final String VNUM_GROUP  = "VNUM";
+
+        private static final String PRE      = "(?:-(?
[a-zA-Z0-9]+))?";
+        private static final String PRE_GROUP   = "PRE";
+
+        private static final String BUILD
+            = "(?:(?\\+)(?0|[1-9][0-9]*)?)?";
+        private static final String PLUS_GROUP  = "PLUS";
+        private static final String BUILD_GROUP = "BUILD";
+
+        private static final String OPT      = "(?:-(?[-a-zA-Z0-9.]+))?";
+        private static final String OPT_GROUP   = "OPT";
+
+        private static final String VSTR_FORMAT
+            = "^" + VNUM + PRE + BUILD + OPT + "$";
+        private static final Pattern VSTR_PATTERN = Pattern.compile(VSTR_FORMAT);
+
+        /**
+         * Constructs a valid version string containing
+         * a version number followed by pre-release and
+         * build information.
+         *
+         * @param  s
+         *         A string to be interpreted as a version
+         *
+         * @throws  IllegalArgumentException
+         *          If the given string cannot be interpreted as a valid
+         *          version
+         *
+         * @throws  NullPointerException
+         *          If {@code s} is {@code null}
+         *
+         * @throws  NumberFormatException
+         *          If an element of the version number or the build number
+         *          cannot be represented as an {@link Integer}
+         */
+        static Version parse(String s) {
+            if (s == null)
+                throw new NullPointerException();
+
+            Matcher m = VSTR_PATTERN.matcher(s);
+            if (!m.matches())
+                throw new IllegalArgumentException("Invalid version string: '"
+                                                   + s + "'");
+
+            // $VNUM is a dot-separated list of integers of arbitrary length
+            List version = new ArrayList<>();
+            for (String i : m.group(VNUM_GROUP).split("\\."))
+                version.add(Integer.parseInt(i));
+
+            Optional pre = Optional.ofNullable(m.group(PRE_GROUP));
+
+            String b = m.group(BUILD_GROUP);
+            // $BUILD is an integer
+            Optional build = (b == null)
+                ? Optional.empty()
+                : Optional.of(Integer.parseInt(b));
+
+            Optional optional = Optional.ofNullable(m.group(OPT_GROUP));
+
+            // empty '+'
+            if ((m.group(PLUS_GROUP) != null) && !build.isPresent()) {
+                if (optional.isPresent()) {
+                    if (pre.isPresent())
+                        throw new IllegalArgumentException("'+' found with"
+                            + " pre-release and optional components:'" + s
+                            + "'");
+                } else {
+                    throw new IllegalArgumentException("'+' found with neither"
+                        + " build or optional components: '" + s + "'");
+                }
+            }
+            return new Version(version, pre, build, optional);
+        }
+    }
 }
diff --git a/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template b/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template
index dd0e038936d..c5e7b754e6d 100644
--- a/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template
+++ b/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template
@@ -26,6 +26,9 @@
 package java.lang;
 
 import java.io.PrintStream;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Optional;
 
 class VersionProps {
 
@@ -42,6 +45,18 @@ class VersionProps {
     private static final String java_runtime_version =
         "@@VERSION_STRING@@";
 
+    private static final String VERSION_NUMBER =
+        "@@VERSION_NUMBER@@";
+
+    private static final String VERSION_BUILD =
+        "@@VERSION_BUILD@@";
+
+    private static final String VERSION_PRE =
+        "@@VERSION_PRE@@";
+
+    private static final String VERSION_OPT =
+        "@@VERSION_OPT@@";
+
     static {
         init();
     }
@@ -52,6 +67,44 @@ class VersionProps {
         System.setProperty("java.runtime.name", java_runtime_name);
     }
 
+    static List versionNumbers() {
+        List versionNumbers = new ArrayList<>(4);
+        int prevIndex = 0;
+        int index = VERSION_NUMBER.indexOf('.');
+        while (index > 0) {
+            versionNumbers.add(
+                    Integer.parseInt(VERSION_NUMBER, prevIndex, index, 10));
+            prevIndex = index;
+            index = VERSION_NUMBER.indexOf('.', prevIndex);
+        }
+        versionNumbers.add(Integer.parseInt(VERSION_NUMBER,
+                prevIndex, VERSION_NUMBER.length(), 10));
+        return versionNumbers;
+    }
+
+    static Optional pre() {
+        return optionalOf(VERSION_PRE);
+    }
+
+    static Optional build() {
+        return VERSION_BUILD.isEmpty() ?
+                Optional.empty() :
+                Optional.of(Integer.parseInt(VERSION_BUILD));
+    }
+
+    static Optional optional() {
+        return optionalOf(VERSION_OPT);
+    }
+
+    // Treat empty strings as value not being present
+    private static Optional optionalOf(String value) {
+        if (!value.isEmpty()) {
+            return Optional.of(value);
+        } else {
+            return Optional.empty();
+        }
+    }
+
     /**
      * In case you were wondering this method is called by java -version.
      * Sad that it prints to stderr; would be nicer if default printed on
@@ -111,4 +164,4 @@ class VersionProps {
                    java_vm_info + ")");
     }
 
-}
\ No newline at end of file
+}

From 23264135ec1b9fbbb11017bfdd6fa1189e8019e7 Mon Sep 17 00:00:00 2001
From: Mandy Chung 
Date: Mon, 27 Jun 2016 20:22:04 -0700
Subject: [PATCH 057/125] 8159596: Add java --dry-run

Reviewed-by: alanb, ksrini
---
 .../launcher/resources/launcher.properties    |   3 +
 jdk/src/java.base/share/native/libjli/java.c  |  21 +-
 .../launcher/modules/dryrun/DryRunTest.java   | 199 ++++++++++++++++++
 .../modules/dryrun/src/m/module-info.java     |  26 +++
 .../launcher/modules/dryrun/src/m/p/Lib.java  |  30 +++
 .../dryrun/src/test/jdk/test/Main.java        |  30 +++
 .../modules/dryrun/src/test/module-info.java  |  26 +++
 7 files changed, 328 insertions(+), 7 deletions(-)
 create mode 100644 jdk/test/tools/launcher/modules/dryrun/DryRunTest.java
 create mode 100644 jdk/test/tools/launcher/modules/dryrun/src/m/module-info.java
 create mode 100644 jdk/test/tools/launcher/modules/dryrun/src/m/p/Lib.java
 create mode 100644 jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/Main.java
 create mode 100644 jdk/test/tools/launcher/modules/dryrun/src/test/module-info.java

diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties
index 32aa8ec65b3..83b328d7de8 100644
--- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties
+++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties
@@ -60,6 +60,9 @@ java.launcher.opt.footer     =\    -cp [,...]]\n\
 \                  list the observable modules and exit\n\
+\    --dry-run     create VM but do not execute main method.\n\
+\                  This --dry-run option may be useful for validating the\n\
+\                  command-line options such as the module system configuration.\n\
 \    -D=\n\
 \                  set a system property\n\
 \    -verbose:[class|gc|jni]\n\
diff --git a/jdk/src/java.base/share/native/libjli/java.c b/jdk/src/java.base/share/native/libjli/java.c
index c771d993bfe..ffd60727128 100644
--- a/jdk/src/java.base/share/native/libjli/java.c
+++ b/jdk/src/java.base/share/native/libjli/java.c
@@ -68,6 +68,7 @@ static jboolean printVersion = JNI_FALSE; /* print and exit */
 static jboolean showVersion = JNI_FALSE;  /* print but continue */
 static jboolean printUsage = JNI_FALSE;   /* print and exit*/
 static jboolean printXUsage = JNI_FALSE;  /* print and exit*/
+static jboolean dryRun = JNI_FALSE;       /* initialize VM and exit */
 static char     *showSettings = NULL;      /* print but continue */
 static char     *listModules = NULL;
 
@@ -489,14 +490,18 @@ JavaMain(void * _args)
     mainArgs = CreateApplicationArgs(env, argv, argc);
     CHECK_EXCEPTION_NULL_LEAVE(mainArgs);
 
-    /* Invoke main method. */
-    (*env)->CallStaticVoidMethod(env, mainClass, mainID, mainArgs);
+    if (dryRun) {
+        ret = 0;
+    } else {
+        /* Invoke main method. */
+        (*env)->CallStaticVoidMethod(env, mainClass, mainID, mainArgs);
 
-    /*
-     * The launcher's exit code (in the absence of calls to
-     * System.exit) will be non-zero if main threw an exception.
-     */
-    ret = (*env)->ExceptionOccurred(env) == NULL ? 0 : 1;
+        /*
+         * The launcher's exit code (in the absence of calls to
+         * System.exit) will be non-zero if main threw an exception.
+         */
+        ret = (*env)->ExceptionOccurred(env) == NULL ? 0 : 1;
+    }
     LEAVE();
 }
 
@@ -1203,6 +1208,8 @@ ParseArguments(int *pargc, char ***pargv,
             return JNI_TRUE;
         } else if (JLI_StrCmp(arg, "-showversion") == 0) {
             showVersion = JNI_TRUE;
+        } else if (JLI_StrCmp(arg, "--dry-run") == 0) {
+            dryRun = JNI_TRUE;
         } else if (JLI_StrCmp(arg, "-X") == 0) {
             printXUsage = JNI_TRUE;
             return JNI_TRUE;
diff --git a/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java
new file mode 100644
index 00000000000..ca87bf88679
--- /dev/null
+++ b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java
@@ -0,0 +1,199 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+/**
+ * @test
+ * @bug 8159596
+ * @library /lib/testlibrary
+ * @modules jdk.compiler
+ *          jdk.jartool/sun.tools.jar
+ * @build DryRunTest CompilerUtils jdk.testlibrary.ProcessTools
+ * @run testng DryRunTest
+ * @summary Test java --dry-run
+ */
+
+import java.io.File;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
+
+import jdk.testlibrary.ProcessTools;
+
+import org.testng.annotations.BeforeTest;
+import org.testng.annotations.Test;
+import static org.testng.Assert.*;
+
+
+@Test
+public class DryRunTest {
+
+    private static final String TEST_SRC = System.getProperty("test.src");
+
+    private static final Path SRC_DIR = Paths.get(TEST_SRC, "src");
+    private static final Path MODS_DIR = Paths.get("mods");
+    private static final Path LIBS_DIR = Paths.get("libs");
+
+    // the module name of the test module
+    private static final String TEST_MODULE = "test";
+    private static final String M_MODULE = "m";
+
+    // the module main class
+    private static final String MAIN_CLASS = "jdk.test.Main";
+
+
+    @BeforeTest
+    public void compileTestModule() throws Exception {
+
+        // javac -d mods/$TESTMODULE src/$TESTMODULE/**
+        assertTrue(CompilerUtils.compile(SRC_DIR.resolve(M_MODULE),
+                                         MODS_DIR,
+                                         "-modulesourcepath", SRC_DIR.toString()));
+
+        assertTrue(CompilerUtils.compile(SRC_DIR.resolve(TEST_MODULE),
+                                         MODS_DIR,
+                                         "-modulesourcepath", SRC_DIR.toString()));
+
+        Files.createDirectories(LIBS_DIR);
+
+        // create JAR files with no module-info.class
+        assertTrue(jar(M_MODULE, "p/Lib.class"));
+        assertTrue(jar(TEST_MODULE, "jdk/test/Main.class"));
+    }
+
+    /**
+     * Execute "java" with the given arguments, returning the exit code.
+     */
+    private int exec(String... args) throws Exception {
+       return ProcessTools.executeTestJava(args)
+                .outputTo(System.out)
+                .errorTo(System.out)
+                .getExitValue();
+    }
+
+
+    /**
+     * Launch module main
+     */
+    public void testModule() throws Exception {
+        String dir = MODS_DIR.toString();
+        String mid = TEST_MODULE + "/" + MAIN_CLASS;
+
+        // java -modulepath mods -module $TESTMODULE/$MAINCLASS
+        // no resolution failure
+        int exitValue = exec("--dry-run", "-modulepath", dir, "-m", mid);
+        assertTrue(exitValue == 0);
+    }
+
+    /**
+     * Test non-existence module in -addmods
+     */
+    public void testNonExistAddModules() throws Exception {
+        String dir = MODS_DIR.toString();
+        String mid = TEST_MODULE + "/" + MAIN_CLASS;
+
+        int exitValue = exec("--dry-run", "-modulepath", dir,
+                             "-addmods", "non.existence",
+                             "-m", mid);
+        assertTrue(exitValue != 0);
+    }
+
+    /**
+     * Launch main class from class path
+     */
+    public void testClassPath() throws Exception {
+        Path testJar = LIBS_DIR.resolve(TEST_MODULE + ".jar");
+        String libs = testJar.toString() + File.pathSeparator +
+                        LIBS_DIR.resolve(M_MODULE + ".jar").toString();
+
+        // test pass with m.jar:test.jar
+        int exitValue = exec("-classpath", libs, MAIN_CLASS);
+        assertTrue(exitValue == 0);
+
+        // m.jar is not on classpath and fails with p.Lib not found
+        exitValue = exec("-classpath", testJar.toString(), MAIN_CLASS);
+        assertTrue(exitValue != 0);
+
+        // dry pass passes since main is not executed
+        exitValue = exec("--dry-run", "-classpath", testJar.toString(), MAIN_CLASS);
+        assertTrue(exitValue == 0);
+    }
+
+    /**
+     * Test automatic modules
+     */
+    public void testAutomaticModule() throws Exception {
+        String libs = LIBS_DIR.resolve(M_MODULE + ".jar").toString() +
+                        File.pathSeparator +
+                        LIBS_DIR.resolve(TEST_MODULE + ".jar").toString();
+        String mid = TEST_MODULE + "/" + MAIN_CLASS;
+
+        // test main method with and without -addmods mm
+        int exitValue = exec("-modulepath", LIBS_DIR.toString(),
+                             "-m", mid);
+        assertTrue(exitValue != 0);
+
+        exitValue = exec("-modulepath", LIBS_DIR.toString(),
+                         "-addmods", M_MODULE,
+                         "-m", mid);
+        assertTrue(exitValue == 0);
+
+        // test dry run with and without -addmods m
+        // no resolution failure
+        exitValue = exec("--dry-run", "-modulepath", LIBS_DIR.toString(),
+                         "-m", mid);
+        assertTrue(exitValue == 0);
+
+        exitValue = exec("--dry-run", "-modulepath", LIBS_DIR.toString(),
+                         "-addmods", M_MODULE,
+                         "-m", mid);
+        assertTrue(exitValue == 0);
+    }
+
+    /**
+     * module m not found
+     */
+    public void testMissingModule() throws Exception {
+        String subdir = MODS_DIR.resolve(TEST_MODULE).toString();
+        String mid = TEST_MODULE + "/" + MAIN_CLASS;
+
+        // resolution failure
+        int exitValue = exec("--dry-run", "-modulepath", subdir, "-m", mid);
+        assertTrue(exitValue != 0);
+    }
+
+    private static boolean jar(String name, String entries) throws IOException {
+        Path jar = LIBS_DIR.resolve(name + ".jar");
+
+        // jar --create ...
+        String classes = MODS_DIR.resolve(name).toString();
+        String[] args = {
+            "--create",
+            "--file=" + jar,
+            "-C", classes, entries
+        };
+        boolean success
+            = new sun.tools.jar.Main(System.out, System.out, "jar").run(args);
+        return success;
+    }
+}
diff --git a/jdk/test/tools/launcher/modules/dryrun/src/m/module-info.java b/jdk/test/tools/launcher/modules/dryrun/src/m/module-info.java
new file mode 100644
index 00000000000..6ebed006a4b
--- /dev/null
+++ b/jdk/test/tools/launcher/modules/dryrun/src/m/module-info.java
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+module m {
+    exports p;
+}
diff --git a/jdk/test/tools/launcher/modules/dryrun/src/m/p/Lib.java b/jdk/test/tools/launcher/modules/dryrun/src/m/p/Lib.java
new file mode 100644
index 00000000000..1c8159b7b13
--- /dev/null
+++ b/jdk/test/tools/launcher/modules/dryrun/src/m/p/Lib.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+package p;
+
+public class Lib {
+    public static void sayHi() {
+        System.out.println("Hello world");
+    }
+}
diff --git a/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/Main.java b/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/Main.java
new file mode 100644
index 00000000000..547e8eb53b0
--- /dev/null
+++ b/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/Main.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+package jdk.test;
+
+public class Main {
+    public static void main(String[] args) {
+        p.Lib.sayHi();
+    }
+}
diff --git a/jdk/test/tools/launcher/modules/dryrun/src/test/module-info.java b/jdk/test/tools/launcher/modules/dryrun/src/test/module-info.java
new file mode 100644
index 00000000000..bc5cd5d4e14
--- /dev/null
+++ b/jdk/test/tools/launcher/modules/dryrun/src/test/module-info.java
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+module test {
+    requires m;
+}

From 8576b106b756eb682b00c0f36b7083346eb10849 Mon Sep 17 00:00:00 2001
From: Athijegannathan Sundararajan 
Date: Tue, 28 Jun 2016 09:57:09 +0530
Subject: [PATCH 058/125] 8160346: JLinkTest.java should compute exact number
 of plugins from jdk.jlink module

Reviewed-by: jlaskey, mchung
---
 jdk/test/tools/jlink/JLinkTest.java | 29 ++++++++++++++++++++---------
 1 file changed, 20 insertions(+), 9 deletions(-)

diff --git a/jdk/test/tools/jlink/JLinkTest.java b/jdk/test/tools/jlink/JLinkTest.java
index 9c95fbf6f67..19b6e6a59d9 100644
--- a/jdk/test/tools/jlink/JLinkTest.java
+++ b/jdk/test/tools/jlink/JLinkTest.java
@@ -53,7 +53,7 @@ import tests.JImageGenerator.InMemoryFile;
  *          jdk.jlink/jdk.tools.jimage
  *          jdk.compiler
  * @build tests.*
- * @run main/othervm -verbose:gc -Xmx1g JLinkTest
+ * @run main/othervm -Xmx1g JLinkTest
  */
 public class JLinkTest {
     // number of built-in plugins from jdk.jlink module
@@ -64,6 +64,10 @@ public class JLinkTest {
                     providers().size();
     }
 
+    private static boolean isOfJLinkModule(Plugin p) {
+        return p.getClass().getModule() == Plugin.class.getModule();
+    }
+
     public static void main(String[] args) throws Exception {
 
         Helper helper = Helper.newHelper();
@@ -72,20 +76,27 @@ public class JLinkTest {
             return;
         }
         helper.generateDefaultModules();
-        int numPlugins = getNumJlinkPlugins();
+        // expected num. of plugins from jdk.jlink module
+        int expectedJLinkPlugins = getNumJlinkPlugins();
+        int totalPlugins = 0;
         {
             // number of built-in plugins
             List builtInPlugins = new ArrayList<>();
             builtInPlugins.addAll(PluginRepository.getPlugins(Layer.boot()));
+            totalPlugins = builtInPlugins.size();
+            // actual num. of plugins loaded from jdk.jlink module
+            int actualJLinkPlugins = 0;
             for (Plugin p : builtInPlugins) {
                 p.getState();
                 p.getType();
+                if (isOfJLinkModule(p)) {
+                    actualJLinkPlugins++;
+                }
             }
-            // Note: other boot layer modules may provide jlink plugins.
-            // We should at least see the builtin plugins from jdk.jlink.
-            if (builtInPlugins.size() < numPlugins) {
-                throw new AssertionError("Found plugins doesn't match expected number : " +
-                        numPlugins + "\n" + builtInPlugins);
+            if (expectedJLinkPlugins != actualJLinkPlugins) {
+                throw new AssertionError("Actual plugins loaded from jdk.jlink: " +
+                        actualJLinkPlugins + " which doesn't match expected number : " +
+                        expectedJLinkPlugins);
             }
         }
 
@@ -150,9 +161,9 @@ public class JLinkTest {
             long number = Stream.of(output.split("\\R"))
                     .filter((s) -> s.matches("Plugin Name:.*"))
                     .count();
-            if (number != numPlugins) {
+            if (number != totalPlugins) {
                 System.err.println(output);
-                throw new AssertionError("Found: " + number + " expected " + numPlugins);
+                throw new AssertionError("Found: " + number + " expected " + totalPlugins);
             }
         }
 

From 0304fe9931b1d2cc1c6b0ad7c580f3460e6ddaad Mon Sep 17 00:00:00 2001
From: Rachna Goel 
Date: Tue, 28 Jun 2016 13:47:01 +0900
Subject: [PATCH 059/125] 8158504:
 test/sun/util/locale/provider/Bug8038436.java: non English locale(s) included
 in available locales

Reviewed-by: okutsu, naoto
---
 .../sun/util/locale/provider/Bug8038436.java  | 26 +++++++++++--------
 1 file changed, 15 insertions(+), 11 deletions(-)

diff --git a/jdk/test/sun/util/locale/provider/Bug8038436.java b/jdk/test/sun/util/locale/provider/Bug8038436.java
index 59931d4969c..3f8179ba0d2 100644
--- a/jdk/test/sun/util/locale/provider/Bug8038436.java
+++ b/jdk/test/sun/util/locale/provider/Bug8038436.java
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2014, 2016 Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -23,24 +23,25 @@
 
 /*
  * @test
- * @bug 8038436
+ * @bug 8038436 8158504
  * @summary Test for changes in 8038436
  * @modules java.base/sun.util.locale.provider
  *          java.base/sun.util.spi
  * @compile -XDignore.symbol.file Bug8038436.java
- * @run main/othervm Bug8038436 -Djava.ext.dirs=foo security
- * @run main/othervm Bug8038436 -Djava.locale.providers=JRE availlocs
+ * @run main/othervm  -limitmods java.base           Bug8038436  security
+ * @run main/othervm  -Djava.locale.providers=COMPAT Bug8038436  availlocs
  */
 
 import java.security.*;
-import java.text.*;
 import java.util.*;
 import java.util.stream.*;
 import sun.util.locale.provider.*;
 
 public class Bug8038436 {
     public static void main(String[] args) {
-        switch (args[1]) {
+
+        switch (args[0]) {
+
         case "security":
             securityTests();
             break;
@@ -50,6 +51,7 @@ public class Bug8038436 {
         default:
             throw new RuntimeException("no test was specified.");
         }
+
     }
 
     private static void securityTests() {
@@ -67,12 +69,14 @@ public class Bug8038436 {
 
         /*
          * Check only English/ROOT locales are returned if the jdk.localedata
-         * module is not installed (implied by "java.ext.dirs" set to "foo").
+         * module is not loaded (implied by "-limitmods java.base").
          */
-        if (Arrays.asList(Locale.getAvailableLocales())
-                .stream()
-                .anyMatch(l -> l != Locale.ROOT && l.getLanguage() != "en")) {
-            throw new RuntimeException("non English locale(s) included in available locales");
+        List nonEnglishLocales= (Arrays.stream(Locale.getAvailableLocales())
+                .filter(l -> (l != Locale.ROOT && !(l.getLanguage() == "en" && (l.getCountry() == "US" || l.getCountry() == "" ))))
+                .collect(Collectors.toList()));
+
+        if (!nonEnglishLocales.isEmpty()) {
+            throw new RuntimeException("non English locale(s)" + nonEnglishLocales + " included in available locales");
         }
     }
 

From e926c778457b2c849b91e76f29bb178a30daafb6 Mon Sep 17 00:00:00 2001
From: Amy Lu 
Date: Tue, 28 Jun 2016 14:39:09 +0800
Subject: [PATCH 060/125] 8156536: Remove intermittent key from TreeTest.java
 and move back to tier1

Reviewed-by: darcy
---
 jdk/test/TEST.groups                           | 2 --
 jdk/test/java/lang/ProcessHandle/TreeTest.java | 1 -
 2 files changed, 3 deletions(-)

diff --git a/jdk/test/TEST.groups b/jdk/test/TEST.groups
index 027a139c9bd..be1540695df 100644
--- a/jdk/test/TEST.groups
+++ b/jdk/test/TEST.groups
@@ -27,7 +27,6 @@
 
 tier1 = \
     :jdk_lang \
-    -java/lang/ProcessHandle/TreeTest.java \
     :jdk_util \
     -java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \
     -java/util/concurrent/forkjoin/FJExceptionTableLeak.java \
@@ -38,7 +37,6 @@ tier1 = \
     tools/pack200
 
 tier2 = \
-    java/lang/ProcessHandle/TreeTest.java \
     java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \
     java/util/concurrent/forkjoin/FJExceptionTableLeak.java \
     :jdk_io \
diff --git a/jdk/test/java/lang/ProcessHandle/TreeTest.java b/jdk/test/java/lang/ProcessHandle/TreeTest.java
index 7ff580053e0..bb62d06353c 100644
--- a/jdk/test/java/lang/ProcessHandle/TreeTest.java
+++ b/jdk/test/java/lang/ProcessHandle/TreeTest.java
@@ -50,7 +50,6 @@ import org.testng.annotations.Test;
  * @build jdk.test.lib.Utils
  * @run testng/othervm TreeTest
  * @summary Test counting and JavaChild.spawning and counting of Processes.
- * @key intermittent
  * @author Roger Riggs
  */
 public class TreeTest extends ProcessUtil {

From 78f385b79a9742ee6a3401b655676909e4af9445 Mon Sep 17 00:00:00 2001
From: Ramanand Patil 
Date: Mon, 27 Jun 2016 11:52:49 +0530
Subject: [PATCH 061/125] 8153955: increase java.util.logging.FileHandler
 MAX_LOCKS limit

This patch adds a new configurable property "java.util.logging.FileHandler.maxLocks" to java.util.logging.FileHandler which can be defined in the logging configuration file and makes it possible to configure the maximum number of concurrent log file locks a FileHandler can handle. If not overridden, the default value of maxLocks (100) remains unchanged.

Reviewed-by: dfuchs, coffeys
---
 .../java/util/logging/FileHandler.java        |  12 +-
 .../share/conf/logging.properties             |   4 +
 .../util/logging/FileHandlerMaxLocksTest.java | 114 ++++++++++++++++++
 3 files changed, 129 insertions(+), 1 deletion(-)
 create mode 100644 jdk/test/java/util/logging/FileHandlerMaxLocksTest.java

diff --git a/jdk/src/java.logging/share/classes/java/util/logging/FileHandler.java b/jdk/src/java.logging/share/classes/java/util/logging/FileHandler.java
index 0778571d3f5..f7d2660b94c 100644
--- a/jdk/src/java.logging/share/classes/java/util/logging/FileHandler.java
+++ b/jdk/src/java.logging/share/classes/java/util/logging/FileHandler.java
@@ -94,6 +94,9 @@ import java.util.Set;
  * 
  • <handler-name>.append * specifies whether the FileHandler should append onto * any existing files (defaults to false).
  • + *
  • <handler-name>.maxLocks + * specifies the maximum number of concurrent locks held by + * FileHandler (defaults to 100).
  • * *

    * For example, the properties for {@code FileHandler} would be: @@ -157,6 +160,7 @@ public class FileHandler extends StreamHandler { private FileChannel lockFileChannel; private File files[]; private static final int MAX_LOCKS = 100; + private int maxLocks = MAX_LOCKS; private static final Set locks = new HashSet<>(); /** @@ -235,6 +239,12 @@ public class FileHandler extends StreamHandler { setLevel(manager.getLevelProperty(cname + ".level", Level.ALL)); setFilter(manager.getFilterProperty(cname + ".filter", null)); setFormatter(manager.getFormatterProperty(cname + ".formatter", new XMLFormatter())); + // Initialize maxLocks from the logging.properties file. + // If invalid/no property is provided 100 will be used as a default value. + maxLocks = manager.getIntProperty(cname + ".maxLocks", MAX_LOCKS); + if(maxLocks <= 0) { + maxLocks = MAX_LOCKS; + } try { setEncoding(manager.getStringProperty(cname +".encoding", null)); } catch (Exception ex) { @@ -476,7 +486,7 @@ public class FileHandler extends StreamHandler { int unique = -1; for (;;) { unique++; - if (unique > MAX_LOCKS) { + if (unique > maxLocks) { throw new IOException("Couldn't get lock for " + pattern); } // Generate a lock file name from the "unique" int. diff --git a/jdk/src/java.logging/share/conf/logging.properties b/jdk/src/java.logging/share/conf/logging.properties index 65cf1b1b7dc..58997e5ff2f 100644 --- a/jdk/src/java.logging/share/conf/logging.properties +++ b/jdk/src/java.logging/share/conf/logging.properties @@ -37,6 +37,10 @@ handlers= java.util.logging.ConsoleHandler java.util.logging.FileHandler.pattern = %h/java%u.log java.util.logging.FileHandler.limit = 50000 java.util.logging.FileHandler.count = 1 +# Default number of locks FileHandler can obtain synchronously. +# This specifies maximum number of attempts to obtain lock file by FileHandler +# implemented by incrementing the unique field %u as per FileHandler API documentation. +java.util.logging.FileHandler.maxLocks = 100 java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter # Limit the message that are printed on the console to INFO and above. diff --git a/jdk/test/java/util/logging/FileHandlerMaxLocksTest.java b/jdk/test/java/util/logging/FileHandlerMaxLocksTest.java new file mode 100644 index 00000000000..fef03b2ef89 --- /dev/null +++ b/jdk/test/java/util/logging/FileHandlerMaxLocksTest.java @@ -0,0 +1,114 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8153955 + * @summary test the FileHandler's new property + * "java.util.logging.FileHandler.maxLocks" which will be present in + * "logging.properties" file with default value of 100. This property can be + * overriden by specifying this property in the custom config file. + * @library /lib/testlibrary + * @build jdk.testlibrary.FileUtils + * @author rpatil + * @run main/othervm FileHandlerMaxLocksTest + */ +import java.io.File; +import java.io.FileWriter; +import java.io.IOException; +import java.nio.file.Paths; +import java.util.ArrayList; +import java.util.List; +import java.util.logging.FileHandler; +import jdk.testlibrary.FileUtils; + +public class FileHandlerMaxLocksTest { + + private static final String LOGGER_DIR = "logger-dir"; + private static final String MAX_LOCK_PROPERTY = "java.util.logging.FileHandler.maxLocks = 200"; + private static final String CONFIG_FILE_NAME = "logging.properties"; + + public static void main(String[] args) throws Exception { + File loggerDir = createLoggerDir(); + String configFilePath = loggerDir.getPath() + File.separator + CONFIG_FILE_NAME; + File configFile = new File(configFilePath); + createFile(configFile, false); + System.setProperty("java.util.logging.config.file", configFilePath); + List fileHandlers = new ArrayList<>(); + try (FileWriter writer = new FileWriter(configFile)) { + writer.write(MAX_LOCK_PROPERTY); + writer.flush(); + // 200 raises the default limit of 100, we try 102 times + for (int i = 0; i < 102; i++) { + fileHandlers.add(new FileHandler(loggerDir.getPath() + File.separator + "test_%u.log")); + } + } catch (IOException ie) { + throw new RuntimeException("Test Failed: " + ie.getMessage()); + } finally { + for (FileHandler fh : fileHandlers) { + fh.close(); + } + FileUtils.deleteFileTreeWithRetry(Paths.get(loggerDir.getPath())); + } + } + + /** + * Create a writable directory in user directory for the test + * + * @return writable directory created that needs to be deleted when done + * @throws RuntimeException + */ + private static File createLoggerDir() throws RuntimeException { + String userDir = System.getProperty("user.dir", "."); + File loggerDir = new File(userDir, LOGGER_DIR); + if (!createFile(loggerDir, true)) { + throw new RuntimeException("Test failed: unable to create" + + " writable working directory " + + loggerDir.getAbsolutePath()); + } + // System.out.println("Created Logger Directory: " + loggerDir.getPath()); + return loggerDir; + } + + /** + * @param newFile File to be created + * @param makeDirectory is File to be created is directory + * @return true if file already exists or creation succeeded + */ + private static boolean createFile(File newFile, boolean makeDirectory) { + if (newFile.exists()) { + return true; + } + if (makeDirectory) { + return newFile.mkdir(); + } else { + try { + return newFile.createNewFile(); + } catch (IOException ie) { + System.err.println("Not able to create file: " + newFile + + ", IOException: " + ie.getMessage()); + return false; + } + } + } +} From ef2abc8eff64e9e4cf05bab0ab393d473675312e Mon Sep 17 00:00:00 2001 From: Jim Laskey Date: Tue, 28 Jun 2016 16:07:23 -0300 Subject: [PATCH 062/125] 8160459: jlink minor code clean up Reviewed-by: mchung --- .../jlink/internal/AbstractModuleEntry.java | 5 +-- .../jdk/tools/jlink/internal/Archive.java | 27 ++++++------- .../internal/ArchiveEntryModuleEntry.java | 4 +- .../jlink/internal/BasicImageWriter.java | 7 ++-- .../jlink/internal/ByteArrayModuleEntry.java | 1 - .../jdk/tools/jlink/internal/DirArchive.java | 4 +- .../jlink/internal/ImageFileCreator.java | 24 ++---------- .../internal/ImagePluginConfiguration.java | 36 ++++++++--------- .../jlink/internal/ImagePluginStack.java | 39 +++++++++---------- .../jlink/internal/ImageResourcesTree.java | 12 ++---- .../jlink/internal/ImageStringsWriter.java | 18 +++++++-- .../jdk/tools/jlink/internal/JarArchive.java | 6 +-- .../jdk/tools/jlink/internal/JlinkTask.java | 3 +- .../jdk/tools/jlink/internal/JmodArchive.java | 7 ++-- .../jlink/internal/ModularJarArchive.java | 3 +- .../jlink/internal/ModuleEntryFactory.java | 1 - .../tools/jlink/internal/ModulePoolImpl.java | 6 +-- .../tools/jlink/internal/PathModuleEntry.java | 5 +-- .../jlink/internal/ResourcePrevisitor.java | 1 - .../jdk/tools/jlink/internal/Utils.java | 1 - .../packager/AppRuntimeImageBuilder.java | 2 +- .../plugins/DefaultCompressPlugin.java | 1 - .../internal/plugins/ExcludeFilesPlugin.java | 3 -- .../jlink/internal/plugins/ExcludePlugin.java | 1 - .../internal/plugins/ExcludeVMPlugin.java | 2 - .../internal/plugins/FileCopierPlugin.java | 2 - .../plugins/GenerateJLIClassesPlugin.java | 2 - .../plugins/IncludeLocalesPlugin.java | 2 - .../internal/plugins/OptimizationPlugin.java | 1 - .../plugins/OrderResourcesPlugin.java | 2 - .../internal/plugins/ReleaseInfoPlugin.java | 1 - .../internal/plugins/StringSharingPlugin.java | 1 - .../internal/plugins/StripDebugPlugin.java | 3 -- .../plugins/StripNativeCommandsPlugin.java | 1 - .../jlink/internal/plugins/ZipPlugin.java | 1 - .../internal/plugins/optim/ControlFlow.java | 8 +--- 36 files changed, 90 insertions(+), 153 deletions(-) diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/AbstractModuleEntry.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/AbstractModuleEntry.java index 19a76ee36b6..25a0c98bbd6 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/AbstractModuleEntry.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/AbstractModuleEntry.java @@ -25,7 +25,6 @@ package jdk.tools.jlink.internal; -import java.io.InputStream; import java.util.Objects; import jdk.tools.jlink.plugin.ModuleEntry; @@ -77,9 +76,7 @@ abstract class AbstractModuleEntry implements ModuleEntry { @Override public int hashCode() { - int hash = 7; - hash = 89 * hash + Objects.hashCode(this.path); - return hash; + return Objects.hashCode(this.path); } @Override diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Archive.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Archive.java index 82571d355e3..5cf159104e0 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Archive.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Archive.java @@ -42,7 +42,6 @@ public interface Archive { public abstract class Entry { public static enum EntryType { - MODULE_NAME, CLASS_OR_RESOURCE, NATIVE_LIB, @@ -57,14 +56,10 @@ public interface Archive { private final String path; public Entry(Archive archive, String path, String name, EntryType type) { - Objects.requireNonNull(archive); - Objects.requireNonNull(path); - Objects.requireNonNull(name); - Objects.requireNonNull(type); - this.archive = archive; - this.path = path; - this.name = name; - this.type = type; + this.archive = Objects.requireNonNull(archive); + this.path = Objects.requireNonNull(path); + this.name = Objects.requireNonNull(name); + this.type = Objects.requireNonNull(type); } public Archive archive() { @@ -79,7 +74,7 @@ public interface Archive { return type; } - /** + /* * Returns the name of this entry. */ public String name() { @@ -91,7 +86,7 @@ public interface Archive { return "type " + type.name() + " path " + path; } - /** + /* * Returns the number of uncompressed bytes for this entry. */ public abstract long size(); @@ -99,17 +94,17 @@ public interface Archive { public abstract InputStream stream() throws IOException; } - /** + /* * The module name. */ String moduleName(); - /** + /* * Returns the path to this module's content */ Path getPath(); - /** + /* * Stream of Entry. * The stream of entries needs to be closed after use * since it might cover lazy I/O based resources. @@ -117,12 +112,12 @@ public interface Archive { */ Stream entries(); - /** + /* * Open the archive */ void open() throws IOException; - /** + /* * Close the archive */ void close() throws IOException; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ArchiveEntryModuleEntry.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ArchiveEntryModuleEntry.java index 6656c935101..f2d15505200 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ArchiveEntryModuleEntry.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ArchiveEntryModuleEntry.java @@ -25,7 +25,6 @@ package jdk.tools.jlink.internal; -import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; import java.io.UncheckedIOException; @@ -46,7 +45,7 @@ final class ArchiveEntryModuleEntry extends AbstractModuleEntry { * @param entry The archive Entry. */ ArchiveEntryModuleEntry(String module, String path, Archive.Entry entry) { - super(module, path, getImageFileType(entry)); + super(module, path, getImageFileType(Objects.requireNonNull(entry))); this.entry = entry; } @@ -65,7 +64,6 @@ final class ArchiveEntryModuleEntry extends AbstractModuleEntry { } private static ModuleEntry.Type getImageFileType(Archive.Entry entry) { - Objects.requireNonNull(entry); switch(entry.type()) { case CLASS_OR_RESOURCE: return ModuleEntry.Type.CLASS_OR_RESOURCE; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/BasicImageWriter.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/BasicImageWriter.java index 559cf690cbb..f499749682d 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/BasicImageWriter.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/BasicImageWriter.java @@ -28,6 +28,7 @@ package jdk.tools.jlink.internal; import java.nio.ByteOrder; import java.util.ArrayList; import java.util.List; +import java.util.Objects; import jdk.internal.jimage.ImageHeader; import jdk.internal.jimage.ImageStream; import jdk.internal.jimage.ImageStringsReader; @@ -54,7 +55,7 @@ public final class BasicImageWriter { } public BasicImageWriter(ByteOrder byteOrder) { - this.byteOrder = byteOrder; + this.byteOrder = Objects.requireNonNull(byteOrder); this.input = new ArrayList<>(); this.strings = new ImageStringsWriter(); this.headerStream = new ImageStream(byteOrder); @@ -96,8 +97,8 @@ public final class BasicImageWriter { private void generatePerfectHash() { PerfectHashBuilder builder = new PerfectHashBuilder<>( - PerfectHashBuilder.Entry.class, // PerfectHashBuilder.Entry().getClass() - PerfectHashBuilder.Bucket.class); // PerfectHashBuilder.Bucket().getClass() + PerfectHashBuilder.Entry.class, + PerfectHashBuilder.Bucket.class); input.forEach((location) -> { builder.put(location.getFullName(), location); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ByteArrayModuleEntry.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ByteArrayModuleEntry.java index 20a016817c4..c40a1d8d387 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ByteArrayModuleEntry.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ByteArrayModuleEntry.java @@ -31,7 +31,6 @@ import java.io.InputStream; import java.io.OutputStream; import java.io.UncheckedIOException; import java.util.Objects; -import jdk.tools.jlink.plugin.ModuleEntry; /** * A ModuleEntry backed by a given byte[]. diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/DirArchive.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/DirArchive.java index 48fd1d5c954..326417c925d 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/DirArchive.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/DirArchive.java @@ -112,13 +112,11 @@ public class DirArchive implements Archive { @Override public Stream entries() { - Stream ret = null; try { - ret = Files.walk(dirPath).map(this::toEntry).filter(n -> n != null); + return Files.walk(dirPath).map(this::toEntry).filter(n -> n != null); } catch (IOException ex) { throw new RuntimeException(ex); } - return ret; } private Archive.Entry toEntry(Path p) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java index 182ce68d538..d492c09f1d5 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java @@ -25,10 +25,8 @@ package jdk.tools.jlink.internal; import java.io.BufferedOutputStream; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; -import java.io.InputStream; import java.io.OutputStream; import java.nio.ByteOrder; import java.nio.file.Files; @@ -47,7 +45,6 @@ import jdk.tools.jlink.internal.Archive.Entry.EntryType; import jdk.tools.jlink.internal.ModulePoolImpl.CompressedModuleData; import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; /** @@ -73,7 +70,7 @@ public final class ImageFileCreator { private final Map> entriesForModule = new HashMap<>(); private final ImagePluginStack plugins; private ImageFileCreator(ImagePluginStack plugins) { - this.plugins = plugins; + this.plugins = Objects.requireNonNull(plugins); } public static ExecutableImage create(Set archives, @@ -232,9 +229,9 @@ public final class ImageFileCreator { out.write(bytes, 0, bytes.length); // write module content - for (ModuleEntry res : content) { + content.stream().forEach((res) -> { res.write(out); - } + }); tree.addContent(out); @@ -283,21 +280,6 @@ public final class ImageFileCreator { return resources; } - private static final int BUF_SIZE = 8192; - - private static byte[] readAllBytes(InputStream is) throws IOException { - ByteArrayOutputStream baos = new ByteArrayOutputStream(); - byte[] buf = new byte[BUF_SIZE]; - while (true) { - int n = is.read(buf); - if (n < 0) { - break; - } - baos.write(buf, 0, n); - } - return baos.toByteArray(); - } - /** * Helper method that splits a Resource path onto 3 items: module, parent * and resource name. diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java index 422029e07d4..a5bd7bf41f8 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java @@ -47,18 +47,18 @@ import jdk.tools.jlink.plugin.TransformerPlugin; */ public final class ImagePluginConfiguration { - private static final List CATEGORIES_ORDER = new ArrayList<>(); + private static final List CATEGORIES_ORDER = new ArrayList<>(); static { - CATEGORIES_ORDER.add(Plugin.Category.FILTER); - CATEGORIES_ORDER.add(Plugin.Category.TRANSFORMER); - CATEGORIES_ORDER.add(Plugin.Category.MODULEINFO_TRANSFORMER); - CATEGORIES_ORDER.add(Plugin.Category.SORTER); - CATEGORIES_ORDER.add(Plugin.Category.COMPRESSOR); - CATEGORIES_ORDER.add(Plugin.Category.METAINFO_ADDER); - CATEGORIES_ORDER.add(Plugin.Category.VERIFIER); - CATEGORIES_ORDER.add(Plugin.Category.PROCESSOR); - CATEGORIES_ORDER.add(Plugin.Category.PACKAGER); + CATEGORIES_ORDER.add(Category.FILTER); + CATEGORIES_ORDER.add(Category.TRANSFORMER); + CATEGORIES_ORDER.add(Category.MODULEINFO_TRANSFORMER); + CATEGORIES_ORDER.add(Category.SORTER); + CATEGORIES_ORDER.add(Category.COMPRESSOR); + CATEGORIES_ORDER.add(Category.METAINFO_ADDER); + CATEGORIES_ORDER.add(Category.VERIFIER); + CATEGORIES_ORDER.add(Category.PROCESSOR); + CATEGORIES_ORDER.add(Category.PACKAGER); } private ImagePluginConfiguration() { @@ -72,8 +72,8 @@ public final class ImagePluginConfiguration { if (pluginsConfiguration == null) { return new ImagePluginStack(); } - Map> plugins = new LinkedHashMap<>(); - for (Plugin.Category cat : CATEGORIES_ORDER) { + Map> plugins = new LinkedHashMap<>(); + for (Category cat : CATEGORIES_ORDER) { plugins.put(cat, new ArrayList<>()); } @@ -96,22 +96,22 @@ public final class ImagePluginConfiguration { List transformerPlugins = new ArrayList<>(); List postProcessingPlugins = new ArrayList<>(); - for (Entry> entry : plugins.entrySet()) { + plugins.entrySet().stream().forEach((entry) -> { // Sort according to plugin constraints List orderedPlugins = PluginOrderingGraph.sort(entry.getValue()); Category category = entry.getKey(); - for (Plugin p : orderedPlugins) { + orderedPlugins.stream().forEach((p) -> { if (category.isPostProcessor()) { @SuppressWarnings("unchecked") - PostProcessorPlugin pp = (PostProcessorPlugin) p; + PostProcessorPlugin pp = (PostProcessorPlugin) p; postProcessingPlugins.add(pp); } else { @SuppressWarnings("unchecked") - TransformerPlugin trans = (TransformerPlugin) p; + TransformerPlugin trans = (TransformerPlugin) p; transformerPlugins.add(trans); } - } - } + }); + }); Plugin lastSorter = null; for (Plugin plugin : transformerPlugins) { if (plugin.getName().equals(pluginsConfiguration.getLastSorterPluginName())) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java index 5b78f5ba696..7d3dd182739 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java @@ -24,7 +24,6 @@ */ package jdk.tools.jlink.internal; -import java.io.ByteArrayInputStream; import java.io.DataOutputStream; import java.io.IOException; import java.lang.module.ModuleDescriptor; @@ -96,7 +95,7 @@ public final class ImagePluginStack { public CheckOrderResourcePool(ByteOrder order, List orderedList, StringTable table) { super(order, table); - this.orderedList = orderedList; + this.orderedList = Objects.requireNonNull(orderedList); } /** @@ -119,7 +118,6 @@ public final class ImagePluginStack { private int currentid = 0; private final Map stringsUsage = new HashMap<>(); - private final Map stringsMap = new HashMap<>(); private final Map reverseMap = new HashMap<>(); @@ -161,12 +159,12 @@ public final class ImagePluginStack { } } + private final ImageBuilder imageBuilder; private final Plugin lastSorter; private final List contentPlugins = new ArrayList<>(); private final List postProcessingPlugins = new ArrayList<>(); private final List resourcePrevisitors = new ArrayList<>(); - private final ImageBuilder imageBuilder; public ImagePluginStack() { this(null, Collections.emptyList(), null, @@ -177,31 +175,32 @@ public final class ImagePluginStack { List contentPlugins, Plugin lastSorter, List postprocessingPlugins) { - Objects.requireNonNull(contentPlugins); + this.imageBuilder = Objects.requireNonNull(imageBuilder); this.lastSorter = lastSorter; - for (TransformerPlugin p : contentPlugins) { + Objects.requireNonNull(contentPlugins); + Objects.requireNonNull(postprocessingPlugins); + contentPlugins.stream().forEach((p) -> { Objects.requireNonNull(p); if (p instanceof ResourcePrevisitor) { resourcePrevisitors.add((ResourcePrevisitor) p); } this.contentPlugins.add(p); - } - for (PostProcessorPlugin p : postprocessingPlugins) { + }); + postprocessingPlugins.stream().forEach((p) -> { Objects.requireNonNull(p); this.postProcessingPlugins.add(p); - } - this.imageBuilder = imageBuilder; + }); } public void operate(ImageProvider provider) throws Exception { ExecutableImage img = provider.retrieve(this); List arguments = new ArrayList<>(); - for (PostProcessorPlugin plugin : postProcessingPlugins) { - List lst = plugin.process(img); - if (lst != null) { - arguments.addAll(lst); - } - } + postProcessingPlugins.stream() + .map((plugin) -> plugin.process(img)) + .filter((lst) -> (lst != null)) + .forEach((lst) -> { + arguments.addAll(lst); + }); img.storeLaunchArgs(arguments); } @@ -230,15 +229,15 @@ public final class ImagePluginStack { resources.getStringTable()); } PreVisitStrings previsit = new PreVisitStrings(); - for (ResourcePrevisitor p : resourcePrevisitors) { + resourcePrevisitors.stream().forEach((p) -> { p.previsit(resources, previsit); - } + }); // Store the strings resulting from the previsit. List sorted = previsit.getSortedStrings(); - for (String s : sorted) { + sorted.stream().forEach((s) -> { resources.getStringTable().addString(s); - } + }); ModulePoolImpl current = resources; List frozenOrder = null; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageResourcesTree.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageResourcesTree.java index 5f64f25baae..2bfaaec5df3 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageResourcesTree.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageResourcesTree.java @@ -113,8 +113,7 @@ public final class ImageResourcesTree { private final boolean isEmpty; PackageReference(String name, boolean isEmpty) { - Objects.requireNonNull(name); - this.name = name; + this.name = Objects.requireNonNull(name); this.isEmpty = isEmpty; } @@ -132,12 +131,8 @@ public final class ImageResourcesTree { private void addReference(String name, boolean isEmpty) { PackageReference ref = references.get(name); - if (ref == null) { + if (ref == null || ref.isEmpty) { references.put(name, new PackageReference(name, isEmpty)); - } else { - if (ref.isEmpty) { // replace with new one incase non empty. - references.put(name, new PackageReference(name, isEmpty)); - } } } @@ -267,8 +262,7 @@ public final class ImageResourcesTree { } // Validate that the packages are well formed. for (Node n : packages.children.values()) { - PackageNode pkg = (PackageNode) n; - pkg.validate(); + ((PackageNode)n).validate(); } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageStringsWriter.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageStringsWriter.java index 30a15a6e458..7ba9b7db72e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageStringsWriter.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageStringsWriter.java @@ -44,9 +44,15 @@ class ImageStringsWriter implements ImageStrings { // Reserve 0 offset for empty string. int offset = addString(""); - assert offset == 0 : "Empty string not zero offset"; + if (offset != 0) { + throw new InternalError("Empty string not offset zero"); + } + // Reserve 1 offset for frequently used ".class". - addString("class"); + offset = addString("class"); + if (offset != 1) { + throw new InternalError("'class' string not offset one"); + } } private int addString(final String string) { @@ -76,7 +82,9 @@ class ImageStringsWriter implements ImageStrings { public String get(int offset) { ByteBuffer buffer = stream.getBuffer(); int capacity = buffer.capacity(); - assert 0 <= offset && offset < capacity : "String buffer offset out of range"; + if (offset < 0 || offset >= capacity) { + throw new InternalError("String buffer offset out of range"); + } int zero = NOT_FOUND; for (int i = offset; i < capacity; i++) { if (buffer.get(i) == '\0') { @@ -84,7 +92,9 @@ class ImageStringsWriter implements ImageStrings { break; } } - assert zero != NOT_FOUND; + if (zero == NOT_FOUND) { + throw new InternalError("String zero terminator not found"); + } int length = zero - offset; byte[] bytes = new byte[length]; int mark = buffer.position(); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JarArchive.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JarArchive.java index 579746f95ce..c7c70dad584 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JarArchive.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JarArchive.java @@ -30,8 +30,6 @@ import java.io.InputStream; import java.io.UncheckedIOException; import java.nio.file.Path; import java.util.Objects; -import java.util.function.Consumer; -import java.util.stream.Collectors; import java.util.stream.Stream; import java.util.zip.ZipEntry; import java.util.zip.ZipFile; @@ -53,8 +51,8 @@ public abstract class JarArchive implements Archive { JarEntry(String path, String name, EntryType type, ZipFile file, ZipEntry entry) { super(JarArchive.this, path, name, type); - this.entry = entry; - this.file = file; + this.entry = Objects.requireNonNull(entry); + this.file = Objects.requireNonNull(file); size = entry.getSize(); } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java index 44c1b43eb5c..c6732081cf1 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java @@ -82,7 +82,7 @@ public class JlinkTask { private static final TaskHelper taskHelper = new TaskHelper(JLINK_BUNDLE); - static Option[] recognizedOptions = { + private static final Option[] recognizedOptions = { new Option(false, (task, opt, arg) -> { task.options.help = true; }, "--help"), @@ -325,7 +325,6 @@ public class JlinkTask { Set limitMods, Set addMods) { - ModuleFinder finder = ModuleFinder.of(paths.toArray(new Path[0])); // jmods are located at link-time diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JmodArchive.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JmodArchive.java index 39a17347e51..5997ea03379 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JmodArchive.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JmodArchive.java @@ -25,7 +25,6 @@ package jdk.tools.jlink.internal; -import jdk.tools.jlink.internal.JarArchive; import java.nio.file.Path; import java.util.Objects; import jdk.tools.jlink.internal.Archive.Entry.EntryType; @@ -35,7 +34,7 @@ import jdk.tools.jlink.internal.Archive.Entry.EntryType; */ public class JmodArchive extends JarArchive { - private static final String JMOD_EXT = ".jmod"; + private static final String JMOD_EXT = ".jmod"; private static final String MODULE_NAME = "module"; private static final String MODULE_INFO = "module-info.class"; private static final String CLASSES = "classes"; @@ -46,8 +45,9 @@ public class JmodArchive extends JarArchive { public JmodArchive(String mn, Path jmod) { super(mn, jmod); String filename = Objects.requireNonNull(jmod.getFileName()).toString(); - if (!filename.endsWith(JMOD_EXT)) + if (!filename.endsWith(JMOD_EXT)) { throw new UnsupportedOperationException("Unsupported format: " + filename); + } } @Override @@ -65,7 +65,6 @@ public class JmodArchive extends JarArchive { case MODULE_NAME: return EntryType.MODULE_NAME; default: - //throw new InternalError("unexpected entry: " + name + " " + zipfile.toString()); //TODO throw new InternalError("unexpected entry: " + section); } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModularJarArchive.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModularJarArchive.java index 3afcfe4947d..0c005fe52e8 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModularJarArchive.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModularJarArchive.java @@ -39,8 +39,9 @@ public class ModularJarArchive extends JarArchive { public ModularJarArchive(String mn, Path jmod) { super(mn, jmod); String filename = Objects.requireNonNull(jmod.getFileName()).toString(); - if (!filename.endsWith(JAR_EXT)) + if (!filename.endsWith(JAR_EXT)) { throw new UnsupportedOperationException("Unsupported format: " + filename); + } } @Override diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModuleEntryFactory.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModuleEntryFactory.java index 61c22ffc457..620e8ffef0b 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModuleEntryFactory.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModuleEntryFactory.java @@ -24,7 +24,6 @@ */ package jdk.tools.jlink.internal; -import java.io.InputStream; import java.nio.file.Path; import java.util.Objects; import jdk.tools.jlink.plugin.ModuleEntry; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModulePoolImpl.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModulePoolImpl.java index dabdb5bb972..467da23ae68 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModulePoolImpl.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ModulePoolImpl.java @@ -24,8 +24,6 @@ */ package jdk.tools.jlink.internal; -import java.io.ByteArrayInputStream; -import java.io.InputStream; import java.lang.module.ModuleDescriptor; import java.nio.ByteBuffer; import java.nio.ByteOrder; @@ -168,8 +166,8 @@ public class ModulePoolImpl implements ModulePool { } public ModulePoolImpl(ByteOrder order, StringTable table) { - this.order = order; - this.table = table; + this.order = Objects.requireNonNull(order); + this.table = Objects.requireNonNull(table); } /** diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PathModuleEntry.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PathModuleEntry.java index 28c56391193..df068cdd65f 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PathModuleEntry.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PathModuleEntry.java @@ -31,7 +31,6 @@ import java.io.UncheckedIOException; import java.nio.file.Files; import java.nio.file.Path; import java.util.Objects; -import jdk.tools.jlink.plugin.ModuleEntry; /** * A ModuleEntry backed by a given nio Path. @@ -43,9 +42,9 @@ public class PathModuleEntry extends AbstractModuleEntry { * Create a new PathModuleEntry. * * @param module The module name. - * @param file The data file identifier. + * @param path The path for the resource content. * @param type The data type. - * @param file The Path for the resource content. + * @param file The data file identifier. */ public PathModuleEntry(String module, String path, Type type, Path file) { super(module, path, type); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ResourcePrevisitor.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ResourcePrevisitor.java index c8b8bc79ed6..c233326ec1f 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ResourcePrevisitor.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ResourcePrevisitor.java @@ -42,7 +42,6 @@ public interface ResourcePrevisitor { * @param resources Read only resources. * @param strings StringTable instance. Add string to the StringTable to track string * usage. - * @throws PluginException */ public void previsit(ModulePool resources, StringTable strings); } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java index f48665e4a57..7a166e1c82c 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java @@ -34,7 +34,6 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.Comparator; import java.util.List; -import java.util.Objects; import java.util.stream.Collectors; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.Plugin.Category; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/packager/AppRuntimeImageBuilder.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/packager/AppRuntimeImageBuilder.java index 7272a6ad5d1..6b05145f278 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/packager/AppRuntimeImageBuilder.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/packager/AppRuntimeImageBuilder.java @@ -127,7 +127,7 @@ public final class AppRuntimeImageBuilder { jlink.build(jlinkConfig, pluginConfig); } - /** + /* * Returns a ModuleFinder that limits observability to the given root * modules, their transitive dependences, plus a set of other modules. */ diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java index d78ae453dda..bc753cfb8cd 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java @@ -24,7 +24,6 @@ */ package jdk.tools.jlink.internal.plugins; -import java.util.Collections; import java.util.Map; import jdk.tools.jlink.internal.ModulePoolImpl; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java index eeb454af0c4..b243ce684ef 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java @@ -24,14 +24,11 @@ */ package jdk.tools.jlink.internal.plugins; -import java.io.UncheckedIOException; -import java.util.Collections; import java.util.Map; import java.util.function.Predicate; import jdk.tools.jlink.plugin.TransformerPlugin; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.internal.Utils; /** * diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java index b3a84ffa853..d193473197e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java @@ -24,7 +24,6 @@ */ package jdk.tools.jlink.internal.plugins; -import java.util.Collections; import java.util.Map; import java.util.function.Predicate; import jdk.tools.jlink.plugin.TransformerPlugin; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java index 6b34a5da436..8553e1a4026 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java @@ -25,12 +25,10 @@ package jdk.tools.jlink.internal.plugins; import java.io.BufferedReader; -import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStreamReader; import java.io.UncheckedIOException; import java.nio.charset.StandardCharsets; -import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java index 8bbd02cdb79..195b596bf72 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java @@ -26,7 +26,6 @@ package jdk.tools.jlink.internal.plugins; import java.io.File; import java.io.IOException; -import java.io.InputStream; import java.io.UncheckedIOException; import java.nio.file.FileVisitResult; import java.nio.file.FileVisitor; @@ -35,7 +34,6 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.nio.file.attribute.BasicFileAttributes; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Objects; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java index 0fe662a0bb9..b9a60ad564a 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java @@ -24,10 +24,8 @@ */ package jdk.tools.jlink.internal.plugins; -import java.io.ByteArrayInputStream; import java.lang.reflect.Method; import java.util.Arrays; -import java.util.Collections; import java.util.EnumSet; import java.util.List; import java.util.Map; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java index 6742d695cc6..fd7a37cf7b0 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java @@ -24,10 +24,8 @@ */ package jdk.tools.jlink.internal.plugins; -import java.io.ByteArrayInputStream; import java.util.ArrayList; import java.util.Arrays; -import java.util.Collections; import java.util.IllformedLocaleException; import java.util.Locale; import java.util.List; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java index d5e9c25be09..d522fa0c7e5 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java @@ -30,7 +30,6 @@ import java.io.OutputStream; import java.io.UncheckedIOException; import java.nio.charset.StandardCharsets; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Objects; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java index 3041f4ac1d2..ac67a5f6413 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java @@ -30,11 +30,9 @@ import java.nio.file.FileSystem; import java.nio.file.Files; import java.nio.file.PathMatcher; import java.util.ArrayList; -import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.Set; import java.util.function.ToIntFunction; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModuleEntry; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java index 1fbf0fbff36..155243a2ebd 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java @@ -26,7 +26,6 @@ package jdk.tools.jlink.internal.plugins; import java.io.FileInputStream; import java.io.IOException; -import java.util.Collections; import java.util.EnumSet; import java.util.HashMap; import java.util.Map; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java index cec1de1a4a1..98cccd12051 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java @@ -46,7 +46,6 @@ import java.io.IOException; import java.io.InputStream; import java.nio.ByteBuffer; import java.util.ArrayList; -import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Map; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java index 62d89651869..65eb1bb7404 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java @@ -24,9 +24,6 @@ */ package jdk.tools.jlink.internal.plugins; -import java.io.ByteArrayInputStream; -import java.util.Arrays; -import java.util.Collections; import java.util.function.Predicate; import jdk.internal.org.objectweb.asm.ClassReader; import jdk.internal.org.objectweb.asm.ClassWriter; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java index 44e3ec52bc8..f70af29558a 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java @@ -24,7 +24,6 @@ */ package jdk.tools.jlink.internal.plugins; -import java.util.Collections; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.TransformerPlugin; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java index b44f2e81e64..366ac079f4c 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java @@ -28,7 +28,6 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.nio.ByteBuffer; import java.util.Arrays; -import java.util.Collections; import java.util.Map; import java.util.function.Predicate; import java.util.zip.Deflater; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java index 977e044373b..d8806666039 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java @@ -76,9 +76,7 @@ public final class ControlFlow { @Override public int hashCode() { - int hash = 3; - hash = 79 * hash + Objects.hashCode(this.firstInstruction); - return hash; + return Objects.hashCode(this.firstInstruction); } @Override @@ -214,9 +212,7 @@ public final class ControlFlow { @Override public int hashCode() { - int hash = 3; - hash = 89 * hash + this.getIndex(); - return hash; + return this.getIndex(); } @Override From ed73972cdafeca4daca965a452dcd49cafa3b1c9 Mon Sep 17 00:00:00 2001 From: Rob McKenna Date: Tue, 28 Jun 2016 20:03:29 +0100 Subject: [PATCH 063/125] 8143640: Showing incorrect result while passing specific argument in the Java launcher tools Reviewed-by: ksrini --- jdk/src/java.base/windows/native/libjli/cmdtoargs.c | 1 + jdk/test/tools/launcher/Arrrghs.java | 4 +++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/jdk/src/java.base/windows/native/libjli/cmdtoargs.c b/jdk/src/java.base/windows/native/libjli/cmdtoargs.c index 80d66a9e324..02c5adf81c9 100644 --- a/jdk/src/java.base/windows/native/libjli/cmdtoargs.c +++ b/jdk/src/java.base/windows/native/libjli/cmdtoargs.c @@ -155,6 +155,7 @@ static char* next_arg(char* cmdline, char* arg, jboolean* wildcard) { } } dest += copyCh(ch, dest); + slashes = 0; break; default: diff --git a/jdk/test/tools/launcher/Arrrghs.java b/jdk/test/tools/launcher/Arrrghs.java index 9045e010473..4d799f35efe 100644 --- a/jdk/test/tools/launcher/Arrrghs.java +++ b/jdk/test/tools/launcher/Arrrghs.java @@ -24,7 +24,7 @@ /** * @test * @bug 5030233 6214916 6356475 6571029 6684582 6742159 4459600 6758881 6753938 - * 6894719 6968053 7151434 7146424 8007333 8077822 + * 6894719 6968053 7151434 7146424 8007333 8077822 8143640 * @summary Argument parsing validation. * @compile -XDignore.symbol.file Arrrghs.java * @run main/othervm Arrrghs @@ -197,6 +197,8 @@ public class Arrrghs extends TestHelper { // more treatment of mixed slashes checkArgumentParsing("f1/ f3\\ f4/", "f1/", "f3\\", "f4/"); checkArgumentParsing("f1/ f2\' ' f3/ f4/", "f1/", "f2\'", "'", "f3/", "f4/"); + + checkArgumentParsing("a\\*\\b", "a\\*\\b"); } private void initEmptyDir(File emptyDir) throws IOException { From c19f3e0db256aeafca34017e6322f022d1e14e45 Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Tue, 28 Jun 2016 15:36:15 -0700 Subject: [PATCH 064/125] 6233323: ZipEntry.isDirectory() may return false incorrectly 8144977: Class.getResourceAsStream("directory") in JAR returns broken InputStream Reviewed-by: rriggs --- .../share/classes/java/util/zip/ZipFile.java | 16 +++++---- jdk/test/java/util/zip/ZipFile/ReadZip.java | 36 ++++++++++++++++++- 2 files changed, 45 insertions(+), 7 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/util/zip/ZipFile.java b/jdk/src/java.base/share/classes/java/util/zip/ZipFile.java index cc9153608e2..ef26d1784cc 100644 --- a/jdk/src/java.base/share/classes/java/util/zip/ZipFile.java +++ b/jdk/src/java.base/share/classes/java/util/zip/ZipFile.java @@ -295,13 +295,13 @@ class ZipFile implements ZipConstants, Closeable { * @throws IllegalStateException if the zip file has been closed */ public ZipEntry getEntry(String name) { - Objects.requireNonNull(name, "name"); synchronized (this) { ensureOpen(); - int pos = zsrc.getEntryPos(zc.getBytes(name), true); + byte[] bname = zc.getBytes(name); + int pos = zsrc.getEntryPos(bname, true); if (pos != -1) { - return getZipEntry(name, pos); + return getZipEntry(name, bname, pos); } } return null; @@ -492,7 +492,7 @@ class ZipFile implements ZipConstants, Closeable { throw new NoSuchElementException(); } // each "entry" has 3 ints in table entries - return getZipEntry(null, zsrc.getEntryPos(i++ * 3)); + return getZipEntry(null, null, zsrc.getEntryPos(i++ * 3)); } } @@ -527,13 +527,17 @@ class ZipFile implements ZipConstants, Closeable { } /* Checks ensureOpen() before invoke this method */ - private ZipEntry getZipEntry(String name, int pos) { + private ZipEntry getZipEntry(String name, byte[] bname, int pos) { byte[] cen = zsrc.cen; int nlen = CENNAM(cen, pos); int elen = CENEXT(cen, pos); int clen = CENCOM(cen, pos); int flag = CENFLG(cen, pos); - if (name == null) { + if (name == null || bname.length != nlen) { + // to use the entry name stored in cen, if the passed in name is + // (1) null, invoked from iterator, or + // (2) not equal to the name stored, a slash is appended during + // getEntryPos() search. if (!zc.isUTF8() && (flag & EFS) != 0) { name = zc.toStringUTF8(cen, pos + CENHDR, nlen); } else { diff --git a/jdk/test/java/util/zip/ZipFile/ReadZip.java b/jdk/test/java/util/zip/ZipFile/ReadZip.java index fe923e81eee..465f1ce3731 100644 --- a/jdk/test/java/util/zip/ZipFile/ReadZip.java +++ b/jdk/test/java/util/zip/ZipFile/ReadZip.java @@ -22,7 +22,7 @@ */ /* @test - @bug 4241361 4842702 4985614 6646605 5032358 6923692 + @bug 4241361 4842702 4985614 6646605 5032358 6923692 6233323 8144977 @summary Make sure we can read a zip file. @key randomness */ @@ -105,6 +105,40 @@ public class ReadZip { newZip.delete(); } + // Read directory entry + try { + try (FileOutputStream fos = new FileOutputStream(newZip); + ZipOutputStream zos = new ZipOutputStream(fos)) + { + ZipEntry ze = new ZipEntry("directory/"); + zos.putNextEntry(ze); + zos.closeEntry(); + } + try (ZipFile zf = new ZipFile(newZip)) { + ZipEntry ze = zf.getEntry("directory/"); + if (ze == null || !ze.isDirectory()) + throw new RuntimeException("read entry \"directory/\" failed"); + try (InputStream is = zf.getInputStream(ze)) { + is.available(); + } catch (Exception x) { + x.printStackTrace(); + } + + ze = zf.getEntry("directory"); + if (ze == null || !ze.isDirectory()) + throw new RuntimeException("read entry \"directory\" failed"); + try (InputStream is = zf.getInputStream(ze)) { + is.available(); + } catch (Exception x) { + x.printStackTrace(); + } + } + } finally { + newZip.delete(); + } + + + // Throw a FNF exception when read a non-existing zip file try { unreached (new ZipFile( new File(System.getProperty("test.src", "."), From 7a7b5b32cfe41a26aa81c100d4dca94465684348 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Tue, 28 Jun 2016 16:57:27 -0700 Subject: [PATCH 065/125] 8160502: Problem listing of several http2 tests Reviewed-by: lancea --- jdk/test/ProblemList.txt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/jdk/test/ProblemList.txt b/jdk/test/ProblemList.txt index 99cf992ccf1..f46c820671e 100644 --- a/jdk/test/ProblemList.txt +++ b/jdk/test/ProblemList.txt @@ -164,6 +164,10 @@ java/net/MulticastSocket/Test.java 7145658 macosx-a java/net/DatagramSocket/SendDatagramToBadAddress.java 7143960 macosx-all +java/net/httpclient/http2/BasicTest.java 8157408 linux-all +java/net/httpclient/http2/ErrorTest.java 8158127 solaris-all,windows-all +java/net/httpclient/http2/TLSConnection.java 8157482 macosx-all + ############################################################################ # jdk_nio From 7dd146f0728a7c1e7597484c2b16086a46d1a13c Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Wed, 29 Jun 2016 08:30:49 +0200 Subject: [PATCH 066/125] 8160439: Replace asserts in VarHandle.AccessMode with tests Reviewed-by: vlivanov, rriggs, martin --- .../classes/java/lang/invoke/VarHandle.java | 12 ---- .../VarHandleTestAccessModeMethodNames.java | 61 +++++++++++++++++++ 2 files changed, 61 insertions(+), 12 deletions(-) create mode 100644 jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessModeMethodNames.java diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java b/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java index ee7be4096bf..f55acf251e2 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java @@ -1275,8 +1275,6 @@ public abstract class VarHandle { this.methodName = methodName; this.at = at; - // Assert method name is correctly derived from value name - assert methodName.equals(toMethodName(name())); // Assert that return type is correct // Otherwise, when disabled avoid using reflection assert at.returnType == getReturnType(methodName); @@ -1311,16 +1309,6 @@ public abstract class VarHandle { throw new IllegalArgumentException("No AccessMode value for method name " + methodName); } - private static String toMethodName(String name) { - StringBuilder s = new StringBuilder(name.toLowerCase()); - int i; - while ((i = s.indexOf("_")) != -1) { - s.deleteCharAt(i); - s.setCharAt(i, Character.toUpperCase(s.charAt(i))); - } - return s.toString(); - } - private static Class getReturnType(String name) { try { Method m = VarHandle.class.getMethod(name, Object[].class); diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessModeMethodNames.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessModeMethodNames.java new file mode 100644 index 00000000000..dc86cc643bc --- /dev/null +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessModeMethodNames.java @@ -0,0 +1,61 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @run testng VarHandleTestAccessModeMethodNames + */ + +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; + +import java.lang.invoke.VarHandle; +import java.util.stream.Stream; + +import static org.testng.Assert.assertEquals; + +public class VarHandleTestAccessModeMethodNames { + + @DataProvider + public static Object[][] accessModesProvider() { + return Stream.of(VarHandle.AccessMode.values()). + map(am -> new Object[]{am}). + toArray(Object[][]::new); + } + + + @Test(dataProvider = "accessModesProvider") + public void testMethodName(VarHandle.AccessMode am) { + assertEquals(am.methodName(), toMethodName(am.name())); + } + + private static String toMethodName(String name) { + StringBuilder s = new StringBuilder(name.toLowerCase()); + int i; + while ((i = s.indexOf("_")) != -1) { + s.deleteCharAt(i); + s.setCharAt(i, Character.toUpperCase(s.charAt(i))); + } + return s.toString(); + } +} From 9f0c345f7f88b0c4db9553d7923734beea345e7a Mon Sep 17 00:00:00 2001 From: Steve Drach Date: Fri, 10 Jun 2016 13:57:51 -0700 Subject: [PATCH 067/125] 8114827: JDK 9 multi-release enabled jar tool Reviewed-by: chegar --- .../jdk/internal/util/jar/JarIndex.java | 3 +- .../share/classes/sun/tools/jar/Main.java | 248 ++++++++---- .../sun/tools/jar/resources/jar.properties | 30 +- .../tools/jar/compat/CLICompatibility.java | 4 +- jdk/test/tools/jar/multiRelease/Basic.java | 354 ++++++++++++++++++ .../data/test01/base/version/Main.java | 8 + .../data/test01/base/version/Version.java | 13 + .../data/test01/v10/version/Version.java | 13 + .../data/test01/v9/version/Version.java | 13 + 9 files changed, 602 insertions(+), 84 deletions(-) create mode 100644 jdk/test/tools/jar/multiRelease/Basic.java create mode 100644 jdk/test/tools/jar/multiRelease/data/test01/base/version/Main.java create mode 100644 jdk/test/tools/jar/multiRelease/data/test01/base/version/Version.java create mode 100644 jdk/test/tools/jar/multiRelease/data/test01/v10/version/Version.java create mode 100644 jdk/test/tools/jar/multiRelease/data/test01/v9/version/Version.java diff --git a/jdk/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java b/jdk/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java index fd92b13bdb9..367ac31b07a 100644 --- a/jdk/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java +++ b/jdk/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java @@ -222,7 +222,8 @@ public class JarIndex { // Any files in META-INF/ will be indexed explicitly if (fileName.equals("META-INF/") || fileName.equals(INDEX_NAME) || - fileName.equals(JarFile.MANIFEST_NAME)) + fileName.equals(JarFile.MANIFEST_NAME) || + fileName.startsWith("META-INF/versions/")) continue; if (!metaInfFilenames || !fileName.startsWith("META-INF/")) { diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java index 85381b79ecc..f33bcf711ce 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/Main.java @@ -48,6 +48,7 @@ import java.util.function.Function; import java.util.function.Supplier; import java.util.regex.Pattern; import java.util.stream.Collectors; +import java.util.stream.Stream; import java.util.zip.*; import java.util.jar.*; import java.util.jar.Pack200.*; @@ -77,24 +78,82 @@ class Main { PrintStream out, err; String fname, mname, ename; String zname = ""; - String[] files; String rootjar = null; - // An entryName(path)->File map generated during "expand", it helps to + private static final int BASE_VERSION = 0; + + class Entry { + final String basename; + final String entryname; + final File file; + final boolean isDir; + + Entry(int version, File file) { + this.file = file; + String path = file.getPath(); + if (file.isDirectory()) { + isDir = true; + path = path.endsWith(File.separator) ? path : + path + File.separator; + } else { + isDir = false; + } + EntryName en = new EntryName(path, version); + basename = en.baseName; + entryname = en.entryName; + } + } + + class EntryName { + final String baseName; + final String entryName; + + EntryName(String name, int version) { + name = name.replace(File.separatorChar, '/'); + String matchPath = ""; + for (String path : pathsMap.get(version)) { + if (name.startsWith(path) + && (path.length() > matchPath.length())) { + matchPath = path; + } + } + name = safeName(name.substring(matchPath.length())); + // the old implementaton doesn't remove + // "./" if it was led by "/" (?) + if (name.startsWith("./")) { + name = name.substring(2); + } + this.baseName = name; + this.entryName = (version > BASE_VERSION) + ? VERSIONS_DIR + version + "/" + this.baseName + : this.baseName; + } + } + + // An entryName(path)->Entry map generated during "expand", it helps to // decide whether or not an existing entry in a jar file needs to be // replaced, during the "update" operation. - Map entryMap = new HashMap(); + Map entryMap = new HashMap<>(); + + // All entries need to be added/updated. + Map entries = new LinkedHashMap<>(); - // All files need to be added/updated. - Set entries = new LinkedHashSet(); // All packages. Set packages = new HashSet<>(); // All actual entries added, or existing, in the jar file ( excl manifest // and module-info.class ). Populated during create or update. Set jarEntries = new HashSet<>(); - // Directories specified by "-C" operation. - Set paths = new HashSet(); + // A paths Set for each version, where each Set contains directories + // specified by the "-C" operation. + Map> pathsMap = new HashMap<>(); + + // There's also a files array per version + Map filesMap = new HashMap<>(); + + // Do we think this is a multi-release jar? Set to true + // if --release option found followed by at least file + boolean isMultiRelease; /* * cflag: create @@ -241,10 +300,15 @@ class Main { if (ename != null) { addMainClass(manifest, ename); } + if (isMultiRelease) { + addMultiRelease(manifest); + } } Map moduleInfoPaths = new HashMap<>(); - expand(null, files, false, moduleInfoPaths); - + for (int version : filesMap.keySet()) { + String[] files = filesMap.get(version); + expand(null, files, false, moduleInfoPaths, version); + } Map moduleInfos = new LinkedHashMap<>(); if (!moduleInfoPaths.isEmpty()) { if (!checkModuleInfos(moduleInfoPaths)) @@ -348,7 +412,10 @@ class Main { (new FileInputStream(mname)) : null; Map moduleInfoPaths = new HashMap<>(); - expand(null, files, true, moduleInfoPaths); + for (int version : filesMap.keySet()) { + String[] files = filesMap.get(version); + expand(null, files, true, moduleInfoPaths, version); + } Map moduleInfos = new HashMap<>(); for (Map.Entry e : moduleInfoPaths.entrySet()) @@ -381,10 +448,11 @@ class Main { tmpFile.delete(); } } else if (tflag) { - replaceFSC(files); + replaceFSC(filesMap); // For the "list table contents" action, access using the // ZipFile class is always most efficient since only a // "one-finger" scan through the central directory is required. + String[] files = filesMapToFiles(filesMap); if (fname != null) { list(fname, files); } else { @@ -396,7 +464,7 @@ class Main { } } } else if (xflag) { - replaceFSC(files); + replaceFSC(filesMap); // For the extract action, when extracting all the entries, // access using the ZipInputStream class is most efficient, // since only a single sequential scan through the zip file is @@ -406,6 +474,8 @@ class Main { // "leading garbage", we fall back from the ZipInputStream // implementation to the ZipFile implementation, since only the // latter can handle it. + + String[] files = filesMapToFiles(filesMap); if (fname != null && files != null) { extract(fname, files); } else { @@ -421,6 +491,7 @@ class Main { } } } else if (iflag) { + String[] files = filesMap.get(BASE_VERSION); // base entries only, can be null genIndex(rootjar, files); } else if (printModuleDescriptor) { boolean found; @@ -449,6 +520,20 @@ class Main { return ok; } + private String[] filesMapToFiles(Map filesMap) { + if (filesMap.isEmpty()) return null; + return filesMap.entrySet() + .stream() + .flatMap(this::filesToEntryNames) + .toArray(String[]::new); + } + + Stream filesToEntryNames(Map.Entry fileEntries) { + int version = fileEntries.getKey(); + return Stream.of(fileEntries.getValue()) + .map(f -> (new EntryName(f, version)).entryName); + } + /** * Parses command line arguments. */ @@ -579,8 +664,10 @@ class Main { /* parse file arguments */ int n = args.length - count; if (n > 0) { + int version = BASE_VERSION; int k = 0; String[] nameBuf = new String[n]; + pathsMap.put(version, new HashSet<>()); try { for (int i = count; i < args.length; i++) { if (args[i].equals("-C")) { @@ -592,8 +679,33 @@ class Main { while (dir.indexOf("//") > -1) { dir = dir.replace("//", "/"); } - paths.add(dir.replace(File.separatorChar, '/')); + pathsMap.get(version).add(dir.replace(File.separatorChar, '/')); nameBuf[k++] = dir + args[++i]; + } else if (args[i].startsWith("--release")) { + int v = BASE_VERSION; + try { + v = Integer.valueOf(args[++i]); + } catch (NumberFormatException x) { + error(formatMsg("error.release.value.notnumber", args[i])); + // this will fall into the next error, thus returning false + } + if (v < 9) { + error(formatMsg("error.release.value.toosmall", String.valueOf(v))); + usageError(); + return false; + } + // associate the files, if any, with the previous version number + if (k > 0) { + String[] files = new String[k]; + System.arraycopy(nameBuf, 0, files, 0, k); + filesMap.put(version, files); + isMultiRelease = version > BASE_VERSION; + } + // reset the counters and start with the new version number + k = 0; + nameBuf = new String[n]; + version = v; + pathsMap.put(version, new HashSet<>()); } else { nameBuf[k++] = args[i]; } @@ -602,8 +714,13 @@ class Main { usageError(); return false; } - files = new String[k]; - System.arraycopy(nameBuf, 0, files, 0, k); + // associate remaining files, if any, with a version + if (k > 0) { + String[] files = new String[k]; + System.arraycopy(nameBuf, 0, files, 0, k); + filesMap.put(version, files); + isMultiRelease = version > BASE_VERSION; + } } else if (cflag && (mname == null)) { error(getMsg("error.bad.cflag")); usageError(); @@ -651,7 +768,8 @@ class Main { void expand(File dir, String[] files, boolean isUpdate, - Map moduleInfoPaths) + Map moduleInfoPaths, + int version) throws IOException { if (files == null) @@ -664,29 +782,29 @@ class Main { else f = new File(dir, files[i]); + Entry entry = new Entry(version, f); + String entryName = entry.entryname; + if (f.isFile()) { - String path = f.getPath(); - String entryName = entryName(path); if (entryName.endsWith(MODULE_INFO)) { moduleInfoPaths.put(entryName, f.toPath()); if (isUpdate) - entryMap.put(entryName, f); - } else if (entries.add(f)) { + entryMap.put(entryName, entry); + } else if (!entries.containsKey(entryName)) { + entries.put(entryName, entry); jarEntries.add(entryName); - if (path.endsWith(".class") && !entryName.startsWith(VERSIONS_DIR)) - packages.add(toPackageName(entryName)); + if (entry.basename.endsWith(".class") && !entryName.startsWith(VERSIONS_DIR)) + packages.add(toPackageName(entry.basename)); if (isUpdate) - entryMap.put(entryName, f); + entryMap.put(entryName, entry); } } else if (f.isDirectory()) { - if (entries.add(f)) { + if (!entries.containsKey(entryName)) { + entries.put(entryName, entry); if (isUpdate) { - String dirPath = f.getPath(); - dirPath = (dirPath.endsWith(File.separator)) ? dirPath : - (dirPath + File.separator); - entryMap.put(entryName(dirPath), f); + entryMap.put(entryName, entry); } - expand(f, f.list(), isUpdate, moduleInfoPaths); + expand(f, f.list(), isUpdate, moduleInfoPaths, version); } } else { error(formatMsg("error.nosuch.fileordir", String.valueOf(f))); @@ -740,8 +858,9 @@ class Main { in.transferTo(zos); zos.closeEntry(); } - for (File file: entries) { - addFile(zos, file); + for (String entryname : entries.keySet()) { + Entry entry = entries.get(entryname); + addFile(zos, entry); } zos.close(); } @@ -823,7 +942,7 @@ class Main { || (Mflag && isManifestEntry)) { continue; } else if (isManifestEntry && ((newManifest != null) || - (ename != null))) { + (ename != null) || isMultiRelease)) { foundManifest = true; if (newManifest != null) { // Don't read from the newManifest InputStream, as we @@ -862,21 +981,21 @@ class Main { zos.putNextEntry(e2); copy(zis, zos); } else { // replace with the new files - File f = entryMap.get(name); - addFile(zos, f); + Entry ent = entryMap.get(name); + addFile(zos, ent); entryMap.remove(name); - entries.remove(f); + entries.remove(name); } jarEntries.add(name); - if (name.endsWith(".class")) + if (name.endsWith(".class") && !(name.startsWith(VERSIONS_DIR))) packages.add(toPackageName(name)); } } // add the remaining new files - for (File f: entries) { - addFile(zos, f); + for (String entryname : entries.keySet()) { + addFile(zos, entries.get(entryname)); } if (!foundManifest) { if (newManifest != null) { @@ -961,6 +1080,9 @@ class Main { if (ename != null) { addMainClass(m, ename); } + if (isMultiRelease) { + addMultiRelease(m); + } ZipEntry e = new ZipEntry(MANIFEST_NAME); e.setTime(System.currentTimeMillis()); if (flag0) { @@ -1016,24 +1138,6 @@ class Main { return name; } - private String entryName(String name) { - name = name.replace(File.separatorChar, '/'); - String matchPath = ""; - for (String path : paths) { - if (name.startsWith(path) - && (path.length() > matchPath.length())) { - matchPath = path; - } - } - name = safeName(name.substring(matchPath.length())); - // the old implementaton doesn't remove - // "./" if it was led by "/" (?) - if (name.startsWith("./")) { - name = name.substring(2); - } - return name; - } - private void addVersion(Manifest m) { Attributes global = m.getMainAttributes(); if (global.getValue(Attributes.Name.MANIFEST_VERSION) == null) { @@ -1058,6 +1162,11 @@ class Main { global.put(Attributes.Name.MAIN_CLASS, mainApp); } + private void addMultiRelease(Manifest m) { + Attributes global = m.getMainAttributes(); + global.put(Attributes.Name.MULTI_RELEASE, "true"); + } + private boolean isAmbiguousMainClass(Manifest m) { if (ename != null) { Attributes global = m.getMainAttributes(); @@ -1073,14 +1182,10 @@ class Main { /** * Adds a new file entry to the ZIP output stream. */ - void addFile(ZipOutputStream zos, File file) throws IOException { - String name = file.getPath(); - boolean isDir = file.isDirectory(); - if (isDir) { - name = name.endsWith(File.separator) ? name : - (name + File.separator); - } - name = entryName(name); + void addFile(ZipOutputStream zos, Entry entry) throws IOException { + File file = entry.file; + String name = entry.entryname; + boolean isDir = entry.isDir; if (name.equals("") || name.equals(".") || name.equals(zname)) { return; @@ -1221,12 +1326,15 @@ class Main { os.updateEntry(e); } - void replaceFSC(String files[]) { - if (files != null) { - for (int i = 0; i < files.length; i++) { - files[i] = files[i].replace(File.separatorChar, '/'); + void replaceFSC(Map filesMap) { + filesMap.keySet().forEach(version -> { + String[] files = filesMap.get(version); + if (files != null) { + for (int i = 0; i < files.length; i++) { + files[i] = files[i].replace(File.separatorChar, '/'); + } } - } + }); } @SuppressWarnings("serial") @@ -1566,7 +1674,7 @@ class Main { /** * Print an error message; like something is broken */ - protected void error(String s) { + void error(String s) { err.println(s); } diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar.properties index 85316dfb00b..e00ee76610d 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar.properties @@ -63,24 +63,28 @@ error.unexpected.module-info=\ error.module.descriptor.not.found=\ Module descriptor not found error.versioned.info.without.root=\ - module-info.class found in versioned section without module-info.class \ + module-info.class found in a versioned directory without module-info.class \ in the root error.versioned.info.name.notequal=\ - module-info.class in versioned section contains incorrect name + module-info.class in a versioned directory contains incorrect name error.versioned.info.requires.public=\ - module-info.class in versioned section contains additional requires public + module-info.class in a versioned directory contains additional requires public error.versioned.info.requires.added=\ - module-info.class in versioned section contains additional requires + module-info.class in a versioned directory contains additional requires error.versioned.info.requires.dropped=\ - module-info.class in versioned section contains missing requires + module-info.class in a versioned directory contains missing requires error.versioned.info.exports.notequal=\ - module-info.class in versioned section contains different exports + module-info.class in a versioned directory contains different exports error.versioned.info.provides.notequal=\ - module-info.class in versioned section contains different provides + module-info.class in a versioned directory contains different provides error.invalid.versioned.module.attribute=\ Invalid module descriptor attribute {0} error.missing.provider=\ Service provider not found: {0} +error.release.value.notnumber=\ + release {0} not valid +error.release.value.toosmall=\ + release {0} not valid, must be >= 9 out.added.manifest=\ added manifest out.added.module-info=\ @@ -109,7 +113,7 @@ out.size=\ usage.compat=\ \Compatibility Interface:\ \n\ -Usage: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ...\n\ +Usage: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files] ...\n\ Options:\n\ \ \ -c create new archive\n\ \ \ -t list table of contents for archive\n\ @@ -141,7 +145,7 @@ main.usage.summary.try=\ Try `jar --help' for more information. main.help.preopt=\ -Usage: jar [OPTION...] [-C dir] files ...\n\ +Usage: jar [OPTION...] [ [--release VERSION] [-C dir] files] ...\n\ jar creates an archive for classes and resources, and can manipulate or\n\ restore individual classes or resources from an archive.\n\ \n\ @@ -156,7 +160,9 @@ restore individual classes or resources from an archive.\n\ \ -C foo/ classes resources\n\ \ # Update an existing non-modular jar to a modular jar:\n\ \ jar --update --file foo.jar --main-class com.foo.Main --module-version 1.0\n\ -\ -C foo/ module-info.class +\ -C foo/ module-info.class\n\ +\ # Create a multi-release jar, placing some files in the META-INF/versions/9 directory:\n\ +\ jar --create --file mr.jar -C foo classes --release 9 -C foo9 classes main.help.opt.main=\ \ Main operation mode:\n main.help.opt.main.create=\ @@ -178,7 +184,9 @@ main.help.opt.any=\ \ -C DIR Change to the specified directory and include the\n\ \ following file main.help.opt.any.file=\ -\ -f, --file=FILE The archive file name +\ -f, --file=FILE The archive file name\n\ +\ --release VERSION Places all following files in a versioned directory\n\ +\ of the jar (i.e. META-INF/versions/VERSION/) main.help.opt.any.verbose=\ \ -v, --verbose Generate verbose output on standard output main.help.opt.create.update=\ diff --git a/jdk/test/tools/jar/compat/CLICompatibility.java b/jdk/test/tools/jar/compat/CLICompatibility.java index 1dd3589362c..75dd1393d99 100644 --- a/jdk/test/tools/jar/compat/CLICompatibility.java +++ b/jdk/test/tools/jar/compat/CLICompatibility.java @@ -415,14 +415,14 @@ public class CLICompatibility { jar("-h") .assertSuccess() .resultChecker(r -> - assertTrue(r.output.startsWith("Usage: jar [OPTION...] [-C dir] files"), + assertTrue(r.output.startsWith("Usage: jar [OPTION...] [ [--release VERSION] [-C dir] files]"), "Failed, got [" + r.output + "]") ); jar("--help") .assertSuccess() .resultChecker(r -> - assertTrue(r.output.startsWith("Usage: jar [OPTION...] [-C dir] files"), + assertTrue(r.output.startsWith("Usage: jar [OPTION...] [ [--release VERSION] [-C dir] files]"), "Failed, got [" + r.output + "]") ); diff --git a/jdk/test/tools/jar/multiRelease/Basic.java b/jdk/test/tools/jar/multiRelease/Basic.java new file mode 100644 index 00000000000..a1b595338e0 --- /dev/null +++ b/jdk/test/tools/jar/multiRelease/Basic.java @@ -0,0 +1,354 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @library /test/lib/share/classes + * @modules java.base/jdk.internal.misc + * @build jdk.test.lib.JDKToolFinder jdk.test.lib.Platform + * @run testng Basic + */ + +import static org.testng.Assert.*; + +import org.testng.annotations.*; + +import java.io.*; +import java.nio.file.*; +import java.nio.file.attribute.*; +import java.util.*; +import java.util.function.Consumer; +import java.util.jar.*; +import java.util.stream.Stream; +import java.util.zip.*; + +import jdk.test.lib.JDKToolFinder; + +import static java.lang.String.format; +import static java.lang.System.out; + +public class Basic { + private final String src = System.getProperty("test.src", "."); + private final String usr = System.getProperty("user.dir", "."); + + @Test + // create a regular, non-multi-release jar + public void test00() throws IOException { + String jarfile = "test.jar"; + + compile("test01"); //use same data as test01 + + Path classes = Paths.get("classes"); + jar("cf", jarfile, "-C", classes.resolve("base").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, false); + + Map names = Map.of( + "version/Main.class", + new String[] {"base", "version", "Main.class"}, + + "version/Version.class", + new String[] {"base", "version", "Version.class"} + ); + + compare(jarfile, names); + + delete(jarfile); + deleteDir(Paths.get(usr, "classes")); + } + + @Test + // create a multi-release jar + public void test01() throws IOException { + String jarfile = "test.jar"; + + compile("test01"); + + Path classes = Paths.get("classes"); + jar("cf", jarfile, "-C", classes.resolve("base").toString(), ".", + "--release", "9", "-C", classes.resolve("v9").toString(), ".", + "--release", "10", "-C", classes.resolve("v10").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, true); + + Map names = Map.of( + "version/Main.class", + new String[] {"base", "version", "Main.class"}, + + "version/Version.class", + new String[] {"base", "version", "Version.class"}, + + "META-INF/versions/9/version/Version.class", + new String[] {"v9", "version", "Version.class"}, + + "META-INF/versions/10/version/Version.class", + new String[] {"v10", "version", "Version.class"} + ); + + compare(jarfile, names); + + delete(jarfile); + deleteDir(Paths.get(usr, "classes")); + } + + @Test + // update a regular jar to a multi-release jar + public void test02() throws IOException { + String jarfile = "test.jar"; + + compile("test01"); //use same data as test01 + + Path classes = Paths.get("classes"); + jar("cf", jarfile, "-C", classes.resolve("base").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, false); + + jar("uf", jarfile, "--release", "9", "-C", classes.resolve("v9").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, true); + + Map names = Map.of( + "version/Main.class", + new String[] {"base", "version", "Main.class"}, + + "version/Version.class", + new String[] {"base", "version", "Version.class"}, + + "META-INF/versions/9/version/Version.class", + new String[] {"v9", "version", "Version.class"} + ); + + compare(jarfile, names); + + delete(jarfile); + deleteDir(Paths.get(usr, "classes")); + } + + @Test + // replace a base entry and a versioned entry + public void test03() throws IOException { + String jarfile = "test.jar"; + + compile("test01"); //use same data as test01 + + Path classes = Paths.get("classes"); + jar("cf", jarfile, "-C", classes.resolve("base").toString(), ".", + "--release", "9", "-C", classes.resolve("v9").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, true); + + Map names = Map.of( + "version/Main.class", + new String[] {"base", "version", "Main.class"}, + + "version/Version.class", + new String[] {"base", "version", "Version.class"}, + + "META-INF/versions/9/version/Version.class", + new String[] {"v9", "version", "Version.class"} + ); + + compare(jarfile, names); + + // write the v9 version/Version.class entry in base and the v10 + // version/Version.class entry in versions/9 section + jar("uf", jarfile, "-C", classes.resolve("v9").toString(), "version", + "--release", "9", "-C", classes.resolve("v10").toString(), ".") + .assertSuccess(); + + checkMultiRelease(jarfile, true); + + names = Map.of( + "version/Main.class", + new String[] {"base", "version", "Main.class"}, + + "version/Version.class", + new String[] {"v9", "version", "Version.class"}, + + "META-INF/versions/9/version/Version.class", + new String[] {"v10", "version", "Version.class"} + ); + + delete(jarfile); + deleteDir(Paths.get(usr, "classes")); + } + + /* + * Test Infrastructure + */ + private void compile(String test) throws IOException { + Path classes = Paths.get(usr, "classes", "base"); + Files.createDirectories(classes); + Path source = Paths.get(src, "data", test, "base", "version"); + javac(classes, source.resolve("Main.java"), source.resolve("Version.java")); + + classes = Paths.get(usr, "classes", "v9"); + Files.createDirectories(classes); + source = Paths.get(src, "data", test, "v9", "version"); + javac(classes, source.resolve("Version.java")); + + classes = Paths.get(usr, "classes", "v10"); + Files.createDirectories(classes); + source = Paths.get(src, "data", test, "v10", "version"); + javac(classes, source.resolve("Version.java")); + } + + private void checkMultiRelease(String jarFile, boolean expected) throws IOException { + try (JarFile jf = new JarFile(new File(jarFile), true, ZipFile.OPEN_READ, + JarFile.Release.RUNTIME)) { + assertEquals(jf.isMultiRelease(), expected); + } + } + + // compares the bytes found in the jar entries with the bytes found in the + // corresponding data files used to create the entries + private void compare(String jarfile, Map names) throws IOException { + try (JarFile jf = new JarFile(jarfile)) { + for (String name : names.keySet()) { + Path path = Paths.get("classes", names.get(name)); + byte[] b1 = Files.readAllBytes(path); + byte[] b2; + JarEntry je = jf.getJarEntry(name); + try (InputStream is = jf.getInputStream(je)) { + b2 = is.readAllBytes(); + } + assertEquals(b1,b2); + } + } + } + + private void delete(String name) throws IOException { + Files.delete(Paths.get(usr, name)); + } + + private void deleteDir(Path dir) throws IOException { + Files.walkFileTree(dir, new SimpleFileVisitor() { + @Override + public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException { + Files.delete(file); + return FileVisitResult.CONTINUE; + } + + @Override + public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException { + Files.delete(dir); + return FileVisitResult.CONTINUE; + } + }); + } + + /* + * The following methods were taken from modular jar and other jar tests + */ + + void javac(Path dest, Path... sourceFiles) throws IOException { + String javac = JDKToolFinder.getJDKTool("javac"); + + List commands = new ArrayList<>(); + commands.add(javac); + commands.add("-d"); + commands.add(dest.toString()); + Stream.of(sourceFiles).map(Object::toString).forEach(x -> commands.add(x)); + + quickFail(run(new ProcessBuilder(commands))); + } + + Result jarWithStdin(File stdinSource, String... args) { + String jar = JDKToolFinder.getJDKTool("jar"); + List commands = new ArrayList<>(); + commands.add(jar); + Stream.of(args).forEach(x -> commands.add(x)); + ProcessBuilder p = new ProcessBuilder(commands); + if (stdinSource != null) + p.redirectInput(stdinSource); + return run(p); + } + + Result jar(String... args) { + return jarWithStdin(null, args); + } + + void quickFail(Result r) { + if (r.ec != 0) + throw new RuntimeException(r.output); + } + + Result run(ProcessBuilder pb) { + Process p; + out.printf("Running: %s%n", pb.command()); + try { + p = pb.start(); + } catch (IOException e) { + throw new RuntimeException( + format("Couldn't start process '%s'", pb.command()), e); + } + + String output; + try { + output = toString(p.getInputStream(), p.getErrorStream()); + } catch (IOException e) { + throw new RuntimeException( + format("Couldn't read process output '%s'", pb.command()), e); + } + + try { + p.waitFor(); + } catch (InterruptedException e) { + throw new RuntimeException( + format("Process hasn't finished '%s'", pb.command()), e); + } + return new Result(p.exitValue(), output); + } + + String toString(InputStream in1, InputStream in2) throws IOException { + try (ByteArrayOutputStream dst = new ByteArrayOutputStream(); + InputStream concatenated = new SequenceInputStream(in1, in2)) { + concatenated.transferTo(dst); + return new String(dst.toByteArray(), "UTF-8"); + } + } + + static class Result { + final int ec; + final String output; + + private Result(int ec, String output) { + this.ec = ec; + this.output = output; + } + Result assertSuccess() { + assertTrue(ec == 0, format("ec: %d, output: %s", ec, output)); + return this; + } + Result assertFailure() { + assertTrue(ec != 0, format("ec: %d, output: %s", ec, output)); + return this; + } + Result resultChecker(Consumer r) { r.accept(this); return this; } + } +} diff --git a/jdk/test/tools/jar/multiRelease/data/test01/base/version/Main.java b/jdk/test/tools/jar/multiRelease/data/test01/base/version/Main.java new file mode 100644 index 00000000000..4fae52482a6 --- /dev/null +++ b/jdk/test/tools/jar/multiRelease/data/test01/base/version/Main.java @@ -0,0 +1,8 @@ +package version; + +public class Main { + public static void main(String[] args) { + Version v = new Version(); + System.out.println("I am running on version " + v.getVersion()); + } +} diff --git a/jdk/test/tools/jar/multiRelease/data/test01/base/version/Version.java b/jdk/test/tools/jar/multiRelease/data/test01/base/version/Version.java new file mode 100644 index 00000000000..71bd392e821 --- /dev/null +++ b/jdk/test/tools/jar/multiRelease/data/test01/base/version/Version.java @@ -0,0 +1,13 @@ +package version; + +public class Version { + public int getVersion() { + return 8; + } + + protected void doNothing() { + } + + private void reallyDoNothing() { + } +} diff --git a/jdk/test/tools/jar/multiRelease/data/test01/v10/version/Version.java b/jdk/test/tools/jar/multiRelease/data/test01/v10/version/Version.java new file mode 100644 index 00000000000..571d5b4914f --- /dev/null +++ b/jdk/test/tools/jar/multiRelease/data/test01/v10/version/Version.java @@ -0,0 +1,13 @@ +package version; + +public class Version { + public int getVersion() { + return 10; + } + + protected void doNothing() { + } + + private void someName() { + } +} diff --git a/jdk/test/tools/jar/multiRelease/data/test01/v9/version/Version.java b/jdk/test/tools/jar/multiRelease/data/test01/v9/version/Version.java new file mode 100644 index 00000000000..db45a5c8b58 --- /dev/null +++ b/jdk/test/tools/jar/multiRelease/data/test01/v9/version/Version.java @@ -0,0 +1,13 @@ +package version; + +public class Version { + public int getVersion() { + return 9; + } + + protected void doNothing() { + } + + private void anyName() { + } +} From 9eeb285818a10683ca7c8b68d59a7df89f364271 Mon Sep 17 00:00:00 2001 From: Robbin Ehn Date: Mon, 13 Jun 2016 10:10:35 +0200 Subject: [PATCH 068/125] 8072440: serviceability/dcmd/ tests timeout Reviewed-by: sla, mlarsson --- hotspot/test/serviceability/dcmd/framework/HelpTest.java | 1 - .../test/serviceability/dcmd/framework/InvalidCommandTest.java | 1 - hotspot/test/serviceability/dcmd/framework/VMVersionTest.java | 1 - 3 files changed, 3 deletions(-) diff --git a/hotspot/test/serviceability/dcmd/framework/HelpTest.java b/hotspot/test/serviceability/dcmd/framework/HelpTest.java index d03091ef27d..012bcf878ca 100644 --- a/hotspot/test/serviceability/dcmd/framework/HelpTest.java +++ b/hotspot/test/serviceability/dcmd/framework/HelpTest.java @@ -37,7 +37,6 @@ import org.testng.annotations.Test; * java.compiler * java.management * jdk.jvmstat/sun.jvmstat.monitor - * @ignore 8072440 * @build jdk.test.lib.* * @build jdk.test.lib.dcmd.* * @run testng/othervm -XX:+UsePerfData HelpTest diff --git a/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java b/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java index e05da42c499..afd3755714b 100644 --- a/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java +++ b/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java @@ -37,7 +37,6 @@ import org.testng.annotations.Test; * java.compiler * java.management * jdk.jvmstat/sun.jvmstat.monitor - * @ignore 8072440 * @build jdk.test.lib.* * @build jdk.test.lib.dcmd.* * @run testng/othervm -XX:+UsePerfData InvalidCommandTest diff --git a/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java b/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java index 63a3fa73399..7daa95fcaf5 100644 --- a/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java +++ b/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java @@ -38,7 +38,6 @@ import org.testng.annotations.Test; * java.compiler * java.management * jdk.jvmstat/sun.jvmstat.monitor - * @ignore 8072440 * @build jdk.test.lib.* * @build jdk.test.lib.dcmd.* * @run testng/othervm -XX:+UsePerfData VMVersionTest From de7ab979ecc6feceb456f1486bf47ab1f58d64ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Markus=20Gr=C3=B6nlund?= Date: Mon, 13 Jun 2016 11:48:11 +0200 Subject: [PATCH 069/125] 8158033: Notify_tracing() misplaced for intended purpose Reviewed-by: egahlin, dholmes --- hotspot/src/share/vm/runtime/java.cpp | 15 ++++++++------- hotspot/src/share/vm/trace/traceBackend.hpp | 3 --- hotspot/src/share/vm/trace/traceMacros.hpp | 2 ++ hotspot/src/share/vm/utilities/debug.cpp | 11 ----------- hotspot/src/share/vm/utilities/vmError.cpp | 3 +++ 5 files changed, 13 insertions(+), 21 deletions(-) diff --git a/hotspot/src/share/vm/runtime/java.cpp b/hotspot/src/share/vm/runtime/java.cpp index c84153a9157..b854623a8aa 100644 --- a/hotspot/src/share/vm/runtime/java.cpp +++ b/hotspot/src/share/vm/runtime/java.cpp @@ -446,6 +446,14 @@ void before_exit(JavaThread* thread) { os::infinite_sleep(); } + EventThreadEnd event; + if (event.should_commit()) { + event.set_thread(THREAD_TRACE_ID(thread)); + event.commit(); + } + + TRACE_VM_EXIT(); + // Stop the WatcherThread. We do this before disenrolling various // PeriodicTasks to reduce the likelihood of races. if (PeriodicTask::num_tasks() > 0) { @@ -484,13 +492,6 @@ void before_exit(JavaThread* thread) { JvmtiExport::post_thread_end(thread); } - - EventThreadEnd event; - if (event.should_commit()) { - event.set_thread(THREAD_TRACE_ID(thread)); - event.commit(); - } - // Always call even when there are not JVMTI environments yet, since environments // may be attached late and JVMTI must track phases of VM execution JvmtiExport::post_vm_death(); diff --git a/hotspot/src/share/vm/trace/traceBackend.hpp b/hotspot/src/share/vm/trace/traceBackend.hpp index 36635321ad6..57b80ffda34 100644 --- a/hotspot/src/share/vm/trace/traceBackend.hpp +++ b/hotspot/src/share/vm/trace/traceBackend.hpp @@ -48,9 +48,6 @@ public: static void on_unloading_classes(void) { } - static void on_vm_error(bool) { - } - }; class TraceThreadData { diff --git a/hotspot/src/share/vm/trace/traceMacros.hpp b/hotspot/src/share/vm/trace/traceMacros.hpp index 89f14c3691d..63c49630473 100644 --- a/hotspot/src/share/vm/trace/traceMacros.hpp +++ b/hotspot/src/share/vm/trace/traceMacros.hpp @@ -43,6 +43,8 @@ extern "C" void JNICALL trace_register_natives(JNIEnv*, jclass); #define TRACE_REGISTER_NATIVES ((void*)((address_word)(&trace_register_natives))) #define TRACE_START() JNI_OK #define TRACE_INITIALIZE() JNI_OK +#define TRACE_VM_EXIT() +#define TRACE_VM_ERROR() #define TRACE_DEFINE_TRACE_ID_METHODS typedef int ___IGNORED_hs_trace_type1 #define TRACE_DEFINE_TRACE_ID_FIELD typedef int ___IGNORED_hs_trace_type2 diff --git a/hotspot/src/share/vm/utilities/debug.cpp b/hotspot/src/share/vm/utilities/debug.cpp index b2844487530..95fd3b67e44 100644 --- a/hotspot/src/share/vm/utilities/debug.cpp +++ b/hotspot/src/share/vm/utilities/debug.cpp @@ -54,10 +54,6 @@ #include "utilities/macros.hpp" #include "utilities/vmError.hpp" -#if INCLUDE_TRACE -#include "trace/tracing.hpp" -#endif - #include #ifndef ASSERT @@ -306,11 +302,6 @@ void report_out_of_shared_space(SharedSpaceType shared_space) { exit(2); } -static void notify_tracing() { -#if INCLUDE_TRACE - Tracing::on_vm_error(true); -#endif -} void report_insufficient_metaspace(size_t required_size) { warning("\nThe MaxMetaspaceSize of " SIZE_FORMAT " bytes is not large enough.\n" @@ -334,8 +325,6 @@ void report_java_out_of_memory(const char* message) { HeapDumper::dump_heap_from_oome(); } - notify_tracing(); - if (OnOutOfMemoryError && OnOutOfMemoryError[0]) { VMError::report_java_out_of_memory(message); } diff --git a/hotspot/src/share/vm/utilities/vmError.cpp b/hotspot/src/share/vm/utilities/vmError.cpp index 095cc8bbb26..12ed963d17f 100644 --- a/hotspot/src/share/vm/utilities/vmError.cpp +++ b/hotspot/src/share/vm/utilities/vmError.cpp @@ -39,6 +39,7 @@ #include "runtime/vmThread.hpp" #include "runtime/vm_operations.hpp" #include "services/memTracker.hpp" +#include "trace/traceMacros.hpp" #include "utilities/debug.hpp" #include "utilities/decoder.hpp" #include "utilities/defaultStream.hpp" @@ -1165,6 +1166,8 @@ void VMError::report_and_die(int id, const char* message, const char* detail_fmt // are handled properly. reset_signal_handlers(); + TRACE_VM_ERROR(); + } else { // If UseOsErrorReporting we call this for each level of the call stack // while searching for the exception handler. Only the first level needs From fea4ad3fefef78a63b20df839f59099585daa95d Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Mon, 13 Jun 2016 09:02:47 -0400 Subject: [PATCH 070/125] 8158237: JVMTI hides critical debug information for memory leak tracing Remove _backtrace as hidden field, original problem no longer exists Reviewed-by: sspitsyn, jiangli --- hotspot/src/share/vm/runtime/reflectionUtils.cpp | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/runtime/reflectionUtils.cpp b/hotspot/src/share/vm/runtime/reflectionUtils.cpp index fbab2e0fd60..b32d083d7e4 100644 --- a/hotspot/src/share/vm/runtime/reflectionUtils.cpp +++ b/hotspot/src/share/vm/runtime/reflectionUtils.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -73,10 +73,7 @@ GrowableArray *FilteredFieldsMap::_filtered_fields = void FilteredFieldsMap::initialize() { - int offset; - offset = java_lang_Throwable::get_backtrace_offset(); - _filtered_fields->append(new FilteredField(SystemDictionary::Throwable_klass(), offset)); - offset = reflect_ConstantPool::oop_offset(); + int offset = reflect_ConstantPool::oop_offset(); _filtered_fields->append(new FilteredField(SystemDictionary::reflect_ConstantPool_klass(), offset)); offset = reflect_UnsafeStaticFieldAccessorImpl::base_offset(); _filtered_fields->append(new FilteredField(SystemDictionary::reflect_UnsafeStaticFieldAccessorImpl_klass(), offset)); From 0d886c8179d1925d81338084dce28baa63985877 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Mon, 13 Jun 2016 09:03:32 -0400 Subject: [PATCH 071/125] 8158237: JVMTI hides critical debug information for memory leak tracing Remove _backtrace as hidden field, original problem no longer exists Reviewed-by: sspitsyn, jiangli --- jdk/test/com/sun/jdi/BacktraceFieldTest.java | 48 +++++++++++++------- 1 file changed, 31 insertions(+), 17 deletions(-) diff --git a/jdk/test/com/sun/jdi/BacktraceFieldTest.java b/jdk/test/com/sun/jdi/BacktraceFieldTest.java index b993a68ecb1..7136eb97121 100644 --- a/jdk/test/com/sun/jdi/BacktraceFieldTest.java +++ b/jdk/test/com/sun/jdi/BacktraceFieldTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,8 @@ /** * @test * @bug 4446677 - * @summary debuggee crashes when debugging under jbuilder + * @bug 8158237 + * @summary debuggee used to crash when debugging under jbuilder * * @author jjh * @@ -101,6 +102,16 @@ public class BacktraceFieldTest extends TestScaffold { new BacktraceFieldTest(args).startTests(); } + private void printval(ArrayReference backTraceVal, int index) throws Exception { + ArrayReference val = (ArrayReference)backTraceVal.getValue(index); + println("BT: val at " + index + " = " + val); + + // The segv used to happen here for index = 0 + // Now all objects in the backtrace are objects. + Object xVal = (Object)val.getValue(0); + println("BT: xVal = " + xVal); + } + /********** test core **********/ protected void runTests() throws Exception { @@ -128,42 +139,45 @@ public class BacktraceFieldTest extends TestScaffold { * Search through the fields of ee to verify that * java.lang.Throwable.backtrace isn't there. */ + boolean backtrace_found = false; Iterator iter = allFields.iterator(); while(iter.hasNext()) { Field ff = (Field)iter.next(); if (ff.toString().equals("java.lang.Throwable.backtrace")) { - failure("ERROR: java.lang.Throwable.backtrace field not filtered out."); + backtrace_found = true; + println("java.lang.Throwable.backtrace field not filtered out."); /* * If you want to experience the segv this bug causes, change * this test to 1 == 1 and run it with jdk 1.4, build 74 or earlier */ - if (1 == 0) { + if (1 == 1) { // The following code will show the segv that this can cause. ObjectReference myVal = (ObjectReference)myFrame.getValue(lv); println("BT: myVal = " + myVal); - ArrayReference backTraceVal = null; - backTraceVal = (ArrayReference)myVal.getValue(ff); + ArrayReference backTraceVal = (ArrayReference)myVal.getValue(ff); println("BT: backTraceVal = " + backTraceVal); - ArrayReference secondVal = (ArrayReference)backTraceVal.getValue(1); - println("BT: secondVal = " + secondVal); + printval(backTraceVal, 0); + printval(backTraceVal, 1); + printval(backTraceVal, 2); + printval(backTraceVal, 3); // backtrace has 4 elements - Object x2Val = (Object)secondVal.getValue(0); - println("BT: x2Val = " + x2Val); - - ArrayReference firstVal = (ArrayReference)backTraceVal.getValue(0); - println("BT: firstVal = " + firstVal); - - // The segv happens here. - Object xVal = (Object)firstVal.getValue(0); - println("BT: xVal = " + xVal); + try { + printval(backTraceVal, 4); + } catch (Exception e) { + println("Exception " + e); + } } break; } } + if (!backtrace_found) { + failure("ERROR: java.lang.Throwable.backtrace field filtered out."); + } + // Next, verify that we don't accidently discard a field that we shouldn't if (!testFailed) { From 680e1a3a2870f726d0f1fd3206de9bb5fc2e8667 Mon Sep 17 00:00:00 2001 From: Max Ockner Date: Mon, 13 Jun 2016 13:47:21 -0400 Subject: [PATCH 072/125] 8157490: JCK test vm/jni/DefineClass/dfcl001/dfcl00101m1/dfcl00101m1 crashes when run with -Xlog:classload=info Null stream->source() no longer causes error with -Xlog:class+load Reviewed-by: lfoltan, coleenp --- hotspot/src/share/vm/classfile/classFileParser.cpp | 10 +--------- hotspot/src/share/vm/oops/instanceKlass.cpp | 6 +++++- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index a09fc8e14d0..c6155dd6560 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -5356,15 +5356,7 @@ void ClassFileParser::fill_instance_klass(InstanceKlass* ik, bool changed_by_loa if (!is_internal()) { if (log_is_enabled(Info, class, load)) { ResourceMark rm; - const char* module_name = NULL; - static const size_t modules_image_name_len = strlen(MODULES_IMAGE_NAME); - size_t stream_len = strlen(_stream->source()); - // See if _stream->source() ends in "modules" - if (module_entry->is_named() && modules_image_name_len < stream_len && - (strncmp(_stream->source() + stream_len - modules_image_name_len, - MODULES_IMAGE_NAME, modules_image_name_len) == 0)) { - module_name = module_entry->name()->as_C_string(); - } + const char* module_name = (module_entry->name() == NULL) ? UNNAMED_MODULE : module_entry->name()->as_C_string(); if (log_is_enabled(Info, class, load)) { ik->print_loading_log(LogLevel::Info, _loader_data, module_name, _stream); diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index 58135b4a5ff..23d885a991f 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -3004,7 +3004,11 @@ void InstanceKlass::print_loading_log(LogLevel::type type, if (cfs != NULL) { if (cfs->source() != NULL) { if (module_name != NULL) { - log->print(" source: jrt:/%s", module_name); + if (ClassLoader::is_jrt(cfs->source())) { + log->print(" source: jrt:/%s", module_name); + } else { + log->print(" source: %s", cfs->source()); + } } else { log->print(" source: %s", cfs->source()); } From 0f8af0955ce8fdbf3c7e439e1641214bdf56ce3a Mon Sep 17 00:00:00 2001 From: Kirill Zhaldybin Date: Tue, 14 Jun 2016 19:15:27 +0300 Subject: [PATCH 073/125] 8132713: Add tests which check that Humongous objects behave as expected after finishing ConcMark Cycle Reviewed-by: tschatzl, dfazunen --- .../humongousObjects/objectGraphTest/GC.java | 56 +++++++++++++++++++ .../humongousObjects/objectGraphTest/README | 7 +++ .../TestObjectGraphAfterGC.java | 8 +++ 3 files changed, 71 insertions(+) diff --git a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/GC.java b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/GC.java index 17aa97413eb..8da879dec5e 100644 --- a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/GC.java +++ b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/GC.java @@ -38,6 +38,61 @@ import java.util.function.Consumer; * referenced objects after GCs */ public enum GC { + CMC { + @Override + public Runnable get() { + return () -> { + Helpers.waitTillCMCFinished(WHITE_BOX, 0); + WHITE_BOX.g1StartConcMarkCycle(); + Helpers.waitTillCMCFinished(WHITE_BOX, 0); + }; + } + + public Consumer> getChecker() { + return getCheckerImpl(false, false, true, false); + } + + @Override + public List shouldContain() { + return Arrays.asList(GCTokens.WB_INITIATED_CMC); + } + + @Override + public List shouldNotContain() { + return Arrays.asList(GCTokens.WB_INITIATED_YOUNG_GC, GCTokens.WB_INITIATED_MIXED_GC, + GCTokens.FULL_GC, GCTokens.YOUNG_GC); + } + }, + + CMC_NO_SURV_ROOTS { + @Override + public Runnable get() { + return () -> { + WHITE_BOX.youngGC(); + Helpers.waitTillCMCFinished(WHITE_BOX, 0); + WHITE_BOX.youngGC(); + Helpers.waitTillCMCFinished(WHITE_BOX, 0); + + WHITE_BOX.g1StartConcMarkCycle(); + Helpers.waitTillCMCFinished(WHITE_BOX, 0); + }; + } + + public Consumer> getChecker() { + return getCheckerImpl(true, false, true, false); + } + + @Override + public List shouldContain() { + return Arrays.asList(GCTokens.WB_INITIATED_CMC); + } + + @Override + public List shouldNotContain() { + return Arrays.asList(GCTokens.WB_INITIATED_MIXED_GC, + GCTokens.FULL_GC, GCTokens.YOUNG_GC); + } + }, YOUNG_GC { @Override @@ -60,6 +115,7 @@ public enum GC { GCTokens.CMC, GCTokens.YOUNG_GC); } }, + FULL_GC { @Override public Runnable get() { diff --git a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/README b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/README index 1c3522e6ff3..4ec9f0d3792 100644 --- a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/README +++ b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/README @@ -31,6 +31,13 @@ The test checks that after different type of GC unreachable objects behave as ex 3. Full GC with memory pressure - weakly and softly referenced non-humongous and humongous objects are collected. +4. CMC - weakly referenced non-humongous objects are collected, other objects are not collected since weak references + from Young Gen is handled as strong during CMC. + +5. CMC_NO_SURV_ROOTS - weakly referenced non-humongous and humongous objects are collected, softly referenced + non-humongous and humongous objects are not collected since we make 2 Young GC to promote all + weak references to Old Gen. + The test gets gc type as a command line argument. Then the test allocates object graph in heap (currently testing scenarios are pre-generated and stored in TestcaseData.getPregeneratedTestcases()) with TestObjectGraphAfterGC::allocateObjectGraph. diff --git a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java index 53c58b49c09..8e028973547 100644 --- a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java +++ b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java @@ -77,6 +77,14 @@ import java.util.stream.Collectors; * -XX:G1HeapRegionSize=1M -Xlog:gc=info:file=TestObjectGraphAfterGC_FULL_GC_MEMORY_PRESSURE.gc.log * gc.g1.humongousObjects.objectGraphTest.TestObjectGraphAfterGC FULL_GC_MEMORY_PRESSURE * + * @run main/othervm -Xms200M -XX:+UseG1GC -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:. + * -XX:G1HeapRegionSize=1M -Xlog:gc=info:file=TestObjectGraphAfterGC_CMC.gc.log -XX:MaxTenuringThreshold=16 + * gc.g1.humongousObjects.objectGraphTest.TestObjectGraphAfterGC CMC + * + * @run main/othervm -Xms200M -XX:+UseG1GC -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:. + * -XX:G1HeapRegionSize=1M -Xlog:gc=info:file=TestObjectGraphAfterGC_CMC_NO_SURV_ROOTS.gc.log -XX:MaxTenuringThreshold=1 + * gc.g1.humongousObjects.objectGraphTest.TestObjectGraphAfterGC CMC_NO_SURV_ROOTS + * */ /** From ada2d6579395f2f2cb315f5a2163bf9e8bfabb2a Mon Sep 17 00:00:00 2001 From: George Triantafillou Date: Tue, 14 Jun 2016 14:35:34 -0400 Subject: [PATCH 074/125] 8159255: [TESTBUG] XpatchJavaBase.java compilation failure Reviewed-by: lfoltan, hseigel, ddmitriev --- hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java b/hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java index 53a056e760c..3c0e50a58fb 100644 --- a/hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java +++ b/hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java @@ -25,6 +25,7 @@ * @test * @bug 8130399 * @summary Make sure -Xpatch works for java.base. + * @modules java.base/jdk.internal.misc * @library /testlibrary * @compile XpatchMain.java * @run main XpatchJavaBase From 69bdc4f2475606e96b3f5572feb3c1850674e4dc Mon Sep 17 00:00:00 2001 From: George Triantafillou Date: Tue, 14 Jun 2016 14:31:36 -0400 Subject: [PATCH 075/125] 8159328: [TESTBUG] ProblematicFrameTest.java throws an exception (due to trying to access Unsafe) but still passes Reviewed-by: hseigel, ddmitriev --- hotspot/test/runtime/ErrorHandling/ProblematicFrameTest.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/hotspot/test/runtime/ErrorHandling/ProblematicFrameTest.java b/hotspot/test/runtime/ErrorHandling/ProblematicFrameTest.java index df6b9cea1fe..117c4839207 100644 --- a/hotspot/test/runtime/ErrorHandling/ProblematicFrameTest.java +++ b/hotspot/test/runtime/ErrorHandling/ProblematicFrameTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -48,8 +48,9 @@ public class ProblematicFrameTest { public static void main(String[] args) throws Exception { ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( - "-Xmx64m", "-XX:-TransmitErrorReport", "-XX:-CreateCoredumpOnCrash", Crasher.class.getName()); + "-Xmx64m", "-XX:-TransmitErrorReport", "-XaddExports:java.base/jdk.internal.misc=ALL-UNNAMED", "-XX:-CreateCoredumpOnCrash", Crasher.class.getName()); OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldNotContain("Exception in thread"); output.shouldNotMatch("error occurred during error reporting \\(printing problematic frame\\)"); } } From f5b4d9e51f56c67396dc49f20c8330ffda250c96 Mon Sep 17 00:00:00 2001 From: Robbin Ehn Date: Wed, 15 Jun 2016 09:43:42 +0200 Subject: [PATCH 076/125] 8149778: serviceability/tmtools/jstat/GcCapacityTest.java causes JVM to hang during GC Reviewed-by: pliden, stefank --- .../test/serviceability/tmtools/jstat/GcCapacityTest.java | 1 - .../serviceability/tmtools/jstat/utils/GcProvokerImpl.java | 5 +++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/hotspot/test/serviceability/tmtools/jstat/GcCapacityTest.java b/hotspot/test/serviceability/tmtools/jstat/GcCapacityTest.java index 2ed5c0576fd..8e2f56e8b37 100644 --- a/hotspot/test/serviceability/tmtools/jstat/GcCapacityTest.java +++ b/hotspot/test/serviceability/tmtools/jstat/GcCapacityTest.java @@ -33,7 +33,6 @@ import utils.*; * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @build common.* * @build utils.* - * @ignore 8149778 * @run main/othervm -XX:+UsePerfData -Xmx128M GcCapacityTest */ public class GcCapacityTest { diff --git a/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java b/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java index 388b53c5256..f04cdf6a375 100644 --- a/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java +++ b/hotspot/test/serviceability/tmtools/jstat/utils/GcProvokerImpl.java @@ -42,8 +42,9 @@ public class GcProvokerImpl implements GcProvoker { // uses fixed small objects to avoid Humongous objects allocation in G1 int memoryChunk = 2048; List list = new ArrayList<>(); - float used = 0; - while (used < targetUsage * maxMemory) { + long used = 0; + long target = (long) (maxMemory * targetUsage); + while (used < target) { try { list.add(new byte[memoryChunk]); used += memoryChunk; From 048538542ac367bd327ff42cbf5a248bdcb5d574 Mon Sep 17 00:00:00 2001 From: Robbin Ehn Date: Wed, 15 Jun 2016 09:54:12 +0200 Subject: [PATCH 077/125] 8154106: UL Xlog:help regd'g 'rt' tag Reviewed-by: mlarsson, mockner, gtriantafill --- hotspot/src/share/vm/logging/logConfiguration.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/logging/logConfiguration.cpp b/hotspot/src/share/vm/logging/logConfiguration.cpp index 922d4b53c06..ecc1ead0105 100644 --- a/hotspot/src/share/vm/logging/logConfiguration.cpp +++ b/hotspot/src/share/vm/logging/logConfiguration.cpp @@ -484,13 +484,13 @@ void LogConfiguration::print_command_line_help(FILE* out) { " -Xlog:gc::uptime,tid\n" "\t Log messages tagged with 'gc' tag using 'info' level to output 'stdout', using 'uptime' and 'tid' decorations.\n\n" - " -Xlog:gc*=info,rt*=off\n" - "\t Log messages tagged with at least 'gc' using 'info' level, but turn off logging of messages tagged with 'rt'.\n" - "\t (Messages tagged with both 'gc' and 'rt' will not be logged.)\n\n" + " -Xlog:gc*=info,safepoint*=off\n" + "\t Log messages tagged with at least 'gc' using 'info' level, but turn off logging of messages tagged with 'safepoint'.\n" + "\t (Messages tagged with both 'gc' and 'safepoint' will not be logged.)\n\n" - " -Xlog:disable -Xlog:rt=trace:rttrace.txt\n" + " -Xlog:disable -Xlog:safepoint=trace:safepointtrace.txt\n" "\t Turn off all logging, including warnings and errors,\n" - "\t and then enable messages tagged with 'rt' using 'trace' level to file 'rttrace.txt'.\n"); + "\t and then enable messages tagged with 'safepoint' using 'trace' level to file 'safepointtrace.txt'.\n"); } void LogConfiguration::rotate_all_outputs() { From 9707ae0c4e14d0c18b2c6bd930a6ffa9115d4d68 Mon Sep 17 00:00:00 2001 From: Dmitry Samersoff Date: Wed, 15 Jun 2016 11:24:12 +0300 Subject: [PATCH 078/125] 8153278: sun/tools/jps/TestJpsJar.java fails in hs nightly Refactor the test to take pwd right before the check Reviewed-by: dholmes --- jdk/test/sun/tools/jps/JpsBase.java | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/jdk/test/sun/tools/jps/JpsBase.java b/jdk/test/sun/tools/jps/JpsBase.java index f119f613951..d13a4053bd8 100644 --- a/jdk/test/sun/tools/jps/JpsBase.java +++ b/jdk/test/sun/tools/jps/JpsBase.java @@ -35,27 +35,28 @@ import jdk.testlibrary.ProcessTools; */ public final class JpsBase { - private static final String shortProcessName; - private static final String fullProcessName; - /** * The jps output should contain processes' names * (except when jps is started in quite mode). * The expected name of the test process is prepared here. */ - static { + + private static String getShortProcessName() { URL url = JpsBase.class.getResource("JpsBase.class"); boolean isJar = url.getProtocol().equals("jar"); + return (isJar) ? JpsBase.class.getSimpleName() + ".jar" : JpsBase.class.getSimpleName(); + } + private static String getFullProcessName() { + URL url = JpsBase.class.getResource("JpsBase.class"); + boolean isJar = url.getProtocol().equals("jar"); if (isJar) { - shortProcessName = JpsBase.class.getSimpleName() + ".jar"; String urlPath = url.getPath(); File jar = new File(urlPath.substring(urlPath.indexOf("file:") + 5, urlPath.indexOf("jar!") + 3)); - fullProcessName = jar.getAbsolutePath(); - } else { - shortProcessName = JpsBase.class.getSimpleName(); - fullProcessName = JpsBase.class.getName(); + return jar.getAbsolutePath(); } + + return JpsBase.class.getName(); } public static void main(String[] args) throws Exception { @@ -83,6 +84,7 @@ public final class JpsBase { // or the full path name to the application's JAR file: // 30673 /tmp/jtreg/jtreg-workdir/scratch/JpsBase.jar ... isFull = true; + String fullProcessName = getFullProcessName(); pattern = "^" + pid + "\\s+" + replaceSpecialChars(fullProcessName) + ".*"; output.shouldMatch(pattern); break; @@ -120,6 +122,7 @@ public final class JpsBase { // Output should only contain lines with pids after the first line with pid. JpsHelper.verifyJpsOutput(output, "^\\d+\\s+.*"); if (!isFull) { + String shortProcessName = getShortProcessName(); pattern = "^" + pid + "\\s+" + replaceSpecialChars(shortProcessName); if (combination.isEmpty()) { // If no arguments are specified output should only contain From b8668ac945679fd330df45bbfc9a06c0e97aa4be Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Per=20Lid=C3=A9n?= Date: Wed, 15 Jun 2016 10:46:20 +0200 Subject: [PATCH 079/125] 8159350: G1 String deduplication logging malformed Reviewed-by: stefank, sjohanss --- hotspot/src/share/vm/gc/g1/g1StringDedupStat.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/gc/g1/g1StringDedupStat.cpp b/hotspot/src/share/vm/gc/g1/g1StringDedupStat.cpp index a90515e8693..4c3349acae5 100644 --- a/hotspot/src/share/vm/gc/g1/g1StringDedupStat.cpp +++ b/hotspot/src/share/vm/gc/g1/g1StringDedupStat.cpp @@ -80,7 +80,7 @@ void G1StringDedupStat::print_summary(const G1StringDedupStat& last_stat, const log_info(gc, stringdedup)( "Concurrent String Deduplication " G1_STRDEDUP_BYTES_FORMAT_NS "->" G1_STRDEDUP_BYTES_FORMAT_NS "(" G1_STRDEDUP_BYTES_FORMAT_NS "), avg " - G1_STRDEDUP_PERCENT_FORMAT_NS ", " G1_STRDEDUP_TIME_FORMAT "]", + G1_STRDEDUP_PERCENT_FORMAT_NS ", " G1_STRDEDUP_TIME_FORMAT, G1_STRDEDUP_BYTES_PARAM(last_stat._new_bytes), G1_STRDEDUP_BYTES_PARAM(last_stat._new_bytes - last_stat._deduped_bytes), G1_STRDEDUP_BYTES_PARAM(last_stat._deduped_bytes), From eba25b33b9f8e0343a3d8b8fd7f2ebc722f35ac1 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Wed, 15 Jun 2016 09:48:24 -0400 Subject: [PATCH 080/125] 8152271: MemberNameTable doesn't purge stale entries Intern MemberNames in table instead of allocating new entries Reviewed-by: vlivanov, sspitsyn, dholmes --- .../src/share/vm/classfile/javaClasses.cpp | 9 ++++ .../src/share/vm/classfile/javaClasses.hpp | 2 + hotspot/src/share/vm/oops/instanceKlass.cpp | 11 +++-- hotspot/src/share/vm/oops/instanceKlass.hpp | 2 +- hotspot/src/share/vm/prims/jvm.cpp | 2 +- hotspot/src/share/vm/prims/methodHandles.cpp | 41 ++++++++++++++----- hotspot/src/share/vm/prims/methodHandles.hpp | 7 ++-- 7 files changed, 55 insertions(+), 19 deletions(-) diff --git a/hotspot/src/share/vm/classfile/javaClasses.cpp b/hotspot/src/share/vm/classfile/javaClasses.cpp index 4c24c7349c0..4ea507532ea 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.cpp +++ b/hotspot/src/share/vm/classfile/javaClasses.cpp @@ -3245,6 +3245,15 @@ void java_lang_invoke_MemberName::set_vmindex(oop mname, intptr_t index) { mname->address_field_put(_vmindex_offset, (address) index); } +bool java_lang_invoke_MemberName::equals(oop mn1, oop mn2) { + if (mn1 == mn2) { + return true; + } + return (vmtarget(mn1) == vmtarget(mn2) && flags(mn1) == flags(mn2) && + vmindex(mn1) == vmindex(mn2) && + clazz(mn1) == clazz(mn2)); +} + oop java_lang_invoke_LambdaForm::vmentry(oop lform) { assert(is_instance(lform), "wrong type"); return lform->obj_field(_vmentry_offset); diff --git a/hotspot/src/share/vm/classfile/javaClasses.hpp b/hotspot/src/share/vm/classfile/javaClasses.hpp index 2cf71baf2c7..d9113adc4e7 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.hpp +++ b/hotspot/src/share/vm/classfile/javaClasses.hpp @@ -1114,6 +1114,8 @@ class java_lang_invoke_MemberName: AllStatic { static int flags_offset_in_bytes() { return _flags_offset; } static int vmtarget_offset_in_bytes() { return _vmtarget_offset; } static int vmindex_offset_in_bytes() { return _vmindex_offset; } + + static bool equals(oop mt1, oop mt2); }; diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index 23d885a991f..eb2d48e8900 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -2693,7 +2693,7 @@ nmethod* InstanceKlass::lookup_osr_nmethod(const Method* m, int bci, int comp_le return NULL; } -bool InstanceKlass::add_member_name(Handle mem_name) { +oop InstanceKlass::add_member_name(Handle mem_name, bool intern) { jweak mem_name_wref = JNIHandles::make_weak_global(mem_name); MutexLocker ml(MemberNameTable_lock); DEBUG_ONLY(NoSafepointVerifier nsv); @@ -2703,7 +2703,7 @@ bool InstanceKlass::add_member_name(Handle mem_name) { // is called! Method* method = (Method*)java_lang_invoke_MemberName::vmtarget(mem_name()); if (method->is_obsolete()) { - return false; + return NULL; } else if (method->is_old()) { // Replace method with redefined version java_lang_invoke_MemberName::set_vmtarget(mem_name(), method_with_idnum(method->method_idnum())); @@ -2712,8 +2712,11 @@ bool InstanceKlass::add_member_name(Handle mem_name) { if (_member_names == NULL) { _member_names = new (ResourceObj::C_HEAP, mtClass) MemberNameTable(idnum_allocated_count()); } - _member_names->add_member_name(mem_name_wref); - return true; + if (intern) { + return _member_names->find_or_add_member_name(mem_name_wref); + } else { + return _member_names->add_member_name(mem_name_wref); + } } // ----------------------------------------------------------------------------------------------------- diff --git a/hotspot/src/share/vm/oops/instanceKlass.hpp b/hotspot/src/share/vm/oops/instanceKlass.hpp index 000215d14a0..9a690392908 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.hpp +++ b/hotspot/src/share/vm/oops/instanceKlass.hpp @@ -1298,7 +1298,7 @@ public: // JSR-292 support MemberNameTable* member_names() { return _member_names; } void set_member_names(MemberNameTable* member_names) { _member_names = member_names; } - bool add_member_name(Handle member_name); + oop add_member_name(Handle member_name, bool intern); public: // JVMTI support diff --git a/hotspot/src/share/vm/prims/jvm.cpp b/hotspot/src/share/vm/prims/jvm.cpp index a0cb1185487..4da3a6492e5 100644 --- a/hotspot/src/share/vm/prims/jvm.cpp +++ b/hotspot/src/share/vm/prims/jvm.cpp @@ -695,7 +695,7 @@ JVM_ENTRY(jobject, JVM_Clone(JNIEnv* env, jobject handle)) // This can safepoint and redefine method, so need both new_obj and method // in a handle, for two different reasons. new_obj can move, method can be // deleted if nothing is using it on the stack. - m->method_holder()->add_member_name(new_obj()); + m->method_holder()->add_member_name(new_obj(), false); } } diff --git a/hotspot/src/share/vm/prims/methodHandles.cpp b/hotspot/src/share/vm/prims/methodHandles.cpp index d21c0fa30e4..f91cf0dd4d3 100644 --- a/hotspot/src/share/vm/prims/methodHandles.cpp +++ b/hotspot/src/share/vm/prims/methodHandles.cpp @@ -178,7 +178,7 @@ oop MethodHandles::init_MemberName(Handle mname, Handle target) { return NULL; } -oop MethodHandles::init_method_MemberName(Handle mname, CallInfo& info) { +oop MethodHandles::init_method_MemberName(Handle mname, CallInfo& info, bool intern) { assert(info.resolved_appendix().is_null(), "only normal methods here"); methodHandle m = info.resolved_method(); assert(m.not_null(), "null method handle"); @@ -279,13 +279,7 @@ oop MethodHandles::init_method_MemberName(Handle mname, CallInfo& info) { // If relevant, the vtable or itable value is stored as vmindex. // This is done eagerly, since it is readily available without // constructing any new objects. - // TO DO: maybe intern mname_oop - if (m->method_holder()->add_member_name(mname)) { - return mname(); - } else { - // Redefinition caused this to fail. Return NULL (and an exception?) - return NULL; - } + return m->method_holder()->add_member_name(mname, intern); } oop MethodHandles::init_field_MemberName(Handle mname, fieldDescriptor& fd, bool is_setter) { @@ -975,7 +969,9 @@ int MethodHandles::find_MemberNames(KlassHandle k, if (!java_lang_invoke_MemberName::is_instance(result())) return -99; // caller bug! CallInfo info(m); - oop saved = MethodHandles::init_method_MemberName(result, info); + // Since this is going through the methods to create MemberNames, don't search + // for matching methods already in the table + oop saved = MethodHandles::init_method_MemberName(result, info, /*intern*/false); if (saved != result()) results->obj_at_put(rfill-1, saved); // show saved instance to user } else if (++overflow >= overflow_limit) { @@ -1056,9 +1052,34 @@ MemberNameTable::~MemberNameTable() { } } -void MemberNameTable::add_member_name(jweak mem_name_wref) { +oop MemberNameTable::add_member_name(jweak mem_name_wref) { assert_locked_or_safepoint(MemberNameTable_lock); this->push(mem_name_wref); + return JNIHandles::resolve(mem_name_wref); +} + +oop MemberNameTable::find_or_add_member_name(jweak mem_name_wref) { + assert_locked_or_safepoint(MemberNameTable_lock); + oop new_mem_name = JNIHandles::resolve(mem_name_wref); + + // Find matching member name in the list. + // This is linear because these because these are short lists. + int len = this->length(); + int new_index = len; + for (int idx = 0; idx < len; idx++) { + oop mname = JNIHandles::resolve(this->at(idx)); + if (mname == NULL) { + new_index = idx; + continue; + } + if (java_lang_invoke_MemberName::equals(new_mem_name, mname)) { + JNIHandles::destroy_weak_global(mem_name_wref); + return mname; + } + } + // Not found, push the new one, or reuse empty slot + this->at_put_grow(new_index, mem_name_wref); + return new_mem_name; } #if INCLUDE_JVMTI diff --git a/hotspot/src/share/vm/prims/methodHandles.hpp b/hotspot/src/share/vm/prims/methodHandles.hpp index 3a2bcae1a12..b6bc97ea94d 100644 --- a/hotspot/src/share/vm/prims/methodHandles.hpp +++ b/hotspot/src/share/vm/prims/methodHandles.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -66,7 +66,7 @@ class MethodHandles: AllStatic { static Handle new_MemberName(TRAPS); // must be followed by init_MemberName static oop init_MemberName(Handle mname_h, Handle target_h); // compute vmtarget/vmindex from target static oop init_field_MemberName(Handle mname_h, fieldDescriptor& fd, bool is_setter = false); - static oop init_method_MemberName(Handle mname_h, CallInfo& info); + static oop init_method_MemberName(Handle mname_h, CallInfo& info, bool intern = true); static int method_ref_kind(Method* m, bool do_dispatch_if_possible = true); static int find_MemberNames(KlassHandle k, Symbol* name, Symbol* sig, int mflags, KlassHandle caller, @@ -253,7 +253,8 @@ class MemberNameTable : public GrowableArray { public: MemberNameTable(int methods_cnt); ~MemberNameTable(); - void add_member_name(jweak mem_name_ref); + oop add_member_name(jweak mem_name_ref); + oop find_or_add_member_name(jweak mem_name_ref); #if INCLUDE_JVMTI // RedefineClasses() API support: From 6fdbed7699231ead198228038f567c6e98209189 Mon Sep 17 00:00:00 2001 From: Kirill Zhaldybin Date: Wed, 15 Jun 2016 20:43:53 +0300 Subject: [PATCH 081/125] 8156226: DiagnosticCommandImpl::invoke throws not very comprehensive message in case if method exists but signature or parameters are wrong Reviewed-by: mchung, dholmes, dfuchs --- .../management/internal/DiagnosticCommandImpl.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/jdk/src/jdk.management/share/classes/com/sun/management/internal/DiagnosticCommandImpl.java b/jdk/src/jdk.management/share/classes/com/sun/management/internal/DiagnosticCommandImpl.java index 5e149633dcd..62cbf5da9f4 100644 --- a/jdk/src/jdk.management/share/classes/com/sun/management/internal/DiagnosticCommandImpl.java +++ b/jdk/src/jdk.management/share/classes/com/sun/management/internal/DiagnosticCommandImpl.java @@ -259,9 +259,20 @@ public class DiagnosticCommandImpl extends NotificationEmitterSupport && signature[0] != null && signature[0].compareTo(strArrayClassName) == 0)) { return w.execute((String[]) params[0]); + } else { + throw new ReflectionException( + new NoSuchMethodException(actionName + + ": mismatched signature " + + (signature != null ? Arrays.toString(signature) : "[]") + + " or parameters")); } + } else { + throw new ReflectionException( + new NoSuchMethodException("Method " + actionName + + " with signature " + + (signature != null ? Arrays.toString(signature) : "[]") + + " not found")); } - throw new ReflectionException(new NoSuchMethodException(actionName)); } private static String transform(String name) { From f3741800fe03279e9852afc796e1fa6f1f0eba01 Mon Sep 17 00:00:00 2001 From: Lois Foltan Date: Thu, 16 Jun 2016 13:34:32 -0400 Subject: [PATCH 082/125] 8156871: Possible concurrency issue with JVM_AddModuleExports Need for single PackageEntry flag to determine a package's unqualifed export state. Reviewed-by: acorn, ctornqvi, dholmes, jiangli --- .../src/share/vm/classfile/moduleEntry.cpp | 10 +- hotspot/src/share/vm/classfile/modules.cpp | 4 +- .../src/share/vm/classfile/packageEntry.cpp | 8 +- .../src/share/vm/classfile/packageEntry.hpp | 7 +- .../test/runtime/modules/CompilerUtils.java | 79 +++++++++++++ .../ModuleStress/ExportModuleStressTest.java | 80 +++++++++++++ .../src/jdk.test/module-info.java | 25 +++++ .../ModuleStress/src/jdk.test/test/Main.java | 105 ++++++++++++++++++ .../src/jdk.translet/module-info.java | 27 +++++ .../src/jdk.translet/translet/Main.java | 30 +++++ 10 files changed, 359 insertions(+), 16 deletions(-) create mode 100644 hotspot/test/runtime/modules/CompilerUtils.java create mode 100644 hotspot/test/runtime/modules/ModuleStress/ExportModuleStressTest.java create mode 100644 hotspot/test/runtime/modules/ModuleStress/src/jdk.test/module-info.java create mode 100644 hotspot/test/runtime/modules/ModuleStress/src/jdk.test/test/Main.java create mode 100644 hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/module-info.java create mode 100644 hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/translet/Main.java diff --git a/hotspot/src/share/vm/classfile/moduleEntry.cpp b/hotspot/src/share/vm/classfile/moduleEntry.cpp index 6d31b8210b6..c507584c712 100644 --- a/hotspot/src/share/vm/classfile/moduleEntry.cpp +++ b/hotspot/src/share/vm/classfile/moduleEntry.cpp @@ -201,7 +201,7 @@ ModuleEntryTable::~ModuleEntryTable() { } void ModuleEntryTable::create_unnamed_module(ClassLoaderData* loader_data) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); // Each ModuleEntryTable has exactly one unnamed module if (loader_data->is_the_null_class_loader_data()) { @@ -227,7 +227,7 @@ void ModuleEntryTable::create_unnamed_module(ClassLoaderData* loader_data) { ModuleEntry* ModuleEntryTable::new_entry(unsigned int hash, Handle module_handle, Symbol* name, Symbol* version, Symbol* location, ClassLoaderData* loader_data) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); ModuleEntry* entry = (ModuleEntry*) NEW_C_HEAP_ARRAY(char, entry_size(), mtModule); // Initialize everything BasicHashtable would @@ -258,7 +258,7 @@ ModuleEntry* ModuleEntryTable::new_entry(unsigned int hash, Handle module_handle } void ModuleEntryTable::add_entry(int index, ModuleEntry* new_entry) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); Hashtable::add_entry(index, (HashtableEntry*)new_entry); } @@ -268,7 +268,7 @@ ModuleEntry* ModuleEntryTable::locked_create_entry_or_null(Handle module_handle, Symbol* module_location, ClassLoaderData* loader_data) { assert(module_name != NULL, "ModuleEntryTable locked_create_entry_or_null should never be called for unnamed module."); - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); // Check if module already exists. if (lookup_only(module_name) != NULL) { return NULL; @@ -309,7 +309,7 @@ void ModuleEntryTable::purge_all_module_reads() { } void ModuleEntryTable::finalize_javabase(Handle module_handle, Symbol* version, Symbol* location) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); ClassLoaderData* boot_loader_data = ClassLoaderData::the_null_class_loader_data(); ModuleEntryTable* module_table = boot_loader_data->modules(); diff --git a/hotspot/src/share/vm/classfile/modules.cpp b/hotspot/src/share/vm/classfile/modules.cpp index 313310047b3..de8aac056b7 100644 --- a/hotspot/src/share/vm/classfile/modules.cpp +++ b/hotspot/src/share/vm/classfile/modules.cpp @@ -568,8 +568,8 @@ void Modules::add_module_exports(jobject from_module, jstring package, jobject t to_module_entry->is_named() ? to_module_entry->name()->as_C_string() : UNNAMED_MODULE); - // Do nothing if modules are the same or if package is already exported unqualifiedly. - if (from_module_entry != to_module_entry && !package_entry->is_unqual_exported()) { + // Do nothing if modules are the same. + if (from_module_entry != to_module_entry) { package_entry->set_exported(to_module_entry); } } diff --git a/hotspot/src/share/vm/classfile/packageEntry.cpp b/hotspot/src/share/vm/classfile/packageEntry.cpp index b7d18756fe1..11cc5ea71aa 100644 --- a/hotspot/src/share/vm/classfile/packageEntry.cpp +++ b/hotspot/src/share/vm/classfile/packageEntry.cpp @@ -49,7 +49,7 @@ bool PackageEntry::is_qexported_to(ModuleEntry* m) const { // Add a module to the package's qualified export list. void PackageEntry::add_qexport(ModuleEntry* m) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); if (!has_qual_exports_list()) { // Lazily create a package's qualified exports list. // Initial size is small, do not anticipate export lists to be large. @@ -157,7 +157,7 @@ PackageEntryTable::~PackageEntryTable() { } PackageEntry* PackageEntryTable::new_entry(unsigned int hash, Symbol* name, ModuleEntry* module) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); PackageEntry* entry = (PackageEntry*) NEW_C_HEAP_ARRAY(char, entry_size(), mtModule); // Initialize everything BasicHashtable would @@ -180,14 +180,14 @@ PackageEntry* PackageEntryTable::new_entry(unsigned int hash, Symbol* name, Modu } void PackageEntryTable::add_entry(int index, PackageEntry* new_entry) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); Hashtable::add_entry(index, (HashtableEntry*)new_entry); } // Create package in loader's package entry table and return the entry. // If entry already exists, return null. Assume Module lock was taken by caller. PackageEntry* PackageEntryTable::locked_create_entry_or_null(Symbol* name, ModuleEntry* module) { - assert_locked_or_safepoint(Module_lock); + assert(Module_lock->owned_by_self(), "should have the Module_lock"); // Check if package already exists. Return NULL if it does. if (lookup_only(name) != NULL) { return NULL; diff --git a/hotspot/src/share/vm/classfile/packageEntry.hpp b/hotspot/src/share/vm/classfile/packageEntry.hpp index 7e19908af07..e1bf62b3aa4 100644 --- a/hotspot/src/share/vm/classfile/packageEntry.hpp +++ b/hotspot/src/share/vm/classfile/packageEntry.hpp @@ -40,11 +40,7 @@ // package is exported to. // // Packages can be exported in the following 3 ways: -// - not exported: the package has not been explicitly qualified to a -// particular module nor has it been specified to be -// unqualifiedly exported to all modules. If all states -// of exportedness are false, the package is considered -// not exported. +// - not exported: the package does not have qualified or unqualified exports. // - qualified exports: the package has been explicitly qualified to at least // one particular module or has been qualifiedly exported // to all unnamed modules. @@ -125,6 +121,7 @@ public: return _is_exported_unqualified; } void set_unqual_exported() { + assert(Module_lock->owned_by_self(), "should have the Module_lock"); _is_exported_unqualified = true; _is_exported_allUnnamed = false; _qualified_exports = NULL; diff --git a/hotspot/test/runtime/modules/CompilerUtils.java b/hotspot/test/runtime/modules/CompilerUtils.java new file mode 100644 index 00000000000..488ec413e8d --- /dev/null +++ b/hotspot/test/runtime/modules/CompilerUtils.java @@ -0,0 +1,79 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import javax.tools.JavaCompiler; +import javax.tools.StandardJavaFileManager; +import javax.tools.StandardLocation; +import javax.tools.ToolProvider; +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.util.Arrays; +import java.util.List; +import java.util.stream.Collectors; + +/** + * This class consists exclusively of static utility methods for invoking the + * java compiler. + * + * This class will eventually move to jdk.testlibrary. + */ + +public final class CompilerUtils { + private CompilerUtils() { } + + /** + * Compile all the java sources in {@code /**} to + * {@code /**}. The destination directory will be created if + * it doesn't exist. + * + * All warnings/errors emitted by the compiler are output to System.out/err. + * + * @return true if the compilation is successful + * + * @throws IOException if there is an I/O error scanning the source tree or + * creating the destination directory + */ + public static boolean compile(Path source, Path destination, String ... options) + throws IOException + { + JavaCompiler compiler = ToolProvider.getSystemJavaCompiler(); + StandardJavaFileManager jfm = compiler.getStandardFileManager(null, null, null); + + List sources + = Files.find(source, Integer.MAX_VALUE, + (file, attrs) -> (file.toString().endsWith(".java"))) + .collect(Collectors.toList()); + + Files.createDirectories(destination); + jfm.setLocationFromPaths(StandardLocation.CLASS_OUTPUT, + Arrays.asList(destination)); + + List opts = Arrays.asList(options); + JavaCompiler.CompilationTask task + = compiler.getTask(null, jfm, null, opts, null, + jfm.getJavaFileObjectsFromPaths(sources)); + + return task.call(); + } +} diff --git a/hotspot/test/runtime/modules/ModuleStress/ExportModuleStressTest.java b/hotspot/test/runtime/modules/ModuleStress/ExportModuleStressTest.java new file mode 100644 index 00000000000..49c75b1d211 --- /dev/null +++ b/hotspot/test/runtime/modules/ModuleStress/ExportModuleStressTest.java @@ -0,0 +1,80 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * @test + * @bug 8156871 + * @summary package in the boot layer is repeatedly exported to unique module created in layers on top of the boot layer + * @modules java.base/jdk.internal.misc + * @library /testlibrary /test/lib + * @compile ../CompilerUtils.java + * @build ExportModuleStressTest + * @run main/othervm ExportModuleStressTest + */ + +import java.nio.file.Path; +import java.nio.file.Paths; +import jdk.test.lib.*; + +public class ExportModuleStressTest { + + private static final String TEST_SRC = System.getProperty("test.src"); + private static final String TEST_CLASSES = System.getProperty("test.classes"); + + private static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); + private static final Path MODS_DIR = Paths.get(TEST_CLASSES, "mods"); + + /** + * Compiles all module definitions used by the test + */ + public static void main(String[] args) throws Exception { + + boolean compiled; + // Compile module jdk.test declaration + compiled = CompilerUtils.compile( + SRC_DIR.resolve("jdk.test"), + MODS_DIR.resolve("jdk.test")); + if (!compiled) { + throw new RuntimeException("Test failed to compile module jdk.test"); + } + + // Compile module jdk.translet declaration + compiled = CompilerUtils.compile( + SRC_DIR.resolve("jdk.translet"), + MODS_DIR.resolve("jdk.translet"), + "-XaddExports:jdk.test/test=jdk.translet", + "-mp", MODS_DIR.toString()); + if (!compiled) { + throw new RuntimeException("Test failed to compile module jdk.translet"); + } + + // Sanity check that the test, jdk.test/test/Main.java + // runs without error. + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( + "-mp", MODS_DIR.toString(), + "-m", "jdk.test/test.Main"); + OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldContain("failed: 0") + .shouldHaveExitValue(0); + } +} diff --git a/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/module-info.java b/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/module-info.java new file mode 100644 index 00000000000..a946224311c --- /dev/null +++ b/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/module-info.java @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +module jdk.test { +} diff --git a/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/test/Main.java b/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/test/Main.java new file mode 100644 index 00000000000..16e8dbc79e1 --- /dev/null +++ b/hotspot/test/runtime/modules/ModuleStress/src/jdk.test/test/Main.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package test; + +import java.lang.module.Configuration; +import java.lang.module.ModuleFinder; +import java.lang.reflect.Layer; +import java.lang.reflect.Method; +import java.lang.reflect.Module; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.util.*; +import java.util.concurrent.Callable; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.Executors; +import java.util.concurrent.Future; + +public class Main { + + private static final Path MODS_DIR = Paths.get(System.getProperty("jdk.module.path")); + static final String MODULE_NAME = "jdk.translet"; + + public static void main(String[] args) throws Exception { + + ModuleFinder finder = ModuleFinder.of(MODS_DIR); + Layer layerBoot = Layer.boot(); + + Configuration cf = layerBoot + .configuration() + .resolveRequires(ModuleFinder.of(), finder, Set.of(MODULE_NAME)); + + Module testModule = Main.class.getModule(); + ClassLoader scl = ClassLoader.getSystemClassLoader(); + + // Create an unique module/class loader in a layer above the boot layer. + // Export this module to the jdk.test/test package. + Callable task = new Callable() { + @Override + public Void call() throws Exception { + Layer layer = Layer.boot().defineModulesWithOneLoader(cf, scl); + Module transletModule = layer.findModule(MODULE_NAME).get(); + testModule.addExports("test", transletModule); + Class c = layer.findLoader(MODULE_NAME).loadClass("translet.Main"); + Method method = c.getDeclaredMethod("go"); + method.invoke(null); + return null; + } + }; + + List> results = new ArrayList<>(); + + // Repeatedly create the layer above stressing the exportation of + // package jdk.test/test to several different modules. + ExecutorService pool = Executors.newFixedThreadPool(Math.min(100, Runtime.getRuntime().availableProcessors()*10)); + try { + for (int i = 0; i < 10000; i++) { + results.add(pool.submit(task)); + } + } finally { + pool.shutdown(); + } + + int passed = 0; + int failed = 0; + + // The failed state should be 0, the created modules in layers above the + // boot layer should be allowed access to the contents of the jdk.test/test + // package since that package was exported to the transletModule above. + for (Future result : results) { + try { + result.get(); + passed++; + } catch (Throwable x) { + x.printStackTrace(); + failed++; + } + } + + System.out.println("passed: " + passed); + System.out.println("failed: " + failed); + } + + public static void callback() { } +} diff --git a/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/module-info.java b/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/module-info.java new file mode 100644 index 00000000000..94f6af4ba23 --- /dev/null +++ b/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/module-info.java @@ -0,0 +1,27 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +module jdk.translet { + requires jdk.test; + exports translet; +} diff --git a/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/translet/Main.java b/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/translet/Main.java new file mode 100644 index 00000000000..30dbaea2577 --- /dev/null +++ b/hotspot/test/runtime/modules/ModuleStress/src/jdk.translet/translet/Main.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package translet; + +public class Main { + public static void go() { + test.Main.callback(); + } +} From 511a5e6cbffbf7789ed3552aa2f51658ed257001 Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Fri, 17 Jun 2016 13:05:53 +0300 Subject: [PATCH 083/125] 8157831: JVMCI tests should not be executed on linux-arm32 Reviewed-by: dpochepk, dholmes --- test/jtreg-ext/requires/VMProps.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/test/jtreg-ext/requires/VMProps.java b/test/jtreg-ext/requires/VMProps.java index ef7de8faf39..468868a7989 100644 --- a/test/jtreg-ext/requires/VMProps.java +++ b/test/jtreg-ext/requires/VMProps.java @@ -52,10 +52,29 @@ public class VMProps implements Callable> { map.put("vm.flavor", vmFlavor()); map.put("vm.compMode", vmCompMode()); map.put("vm.bits", vmBits()); + map.put("vm.simpleArch", vmArch()); dump(map); return map; } + + /** + * @return vm.simpleArch value of "os.simpleArch" property of tested JDK. + */ + protected String vmArch() { + String arch = System.getProperty("os.arch"); + if (arch.equals("x86_64") || arch.equals("amd64")) { + return "x64"; + } + else if (arch.contains("86")) { + return "x86"; + } else { + return arch; + } + } + + + /** * @return VM type value extracted from the "java.vm.name" property. */ From f04cf89a79b450aa7bd5510fbd2bf345b2c55bba Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Fri, 17 Jun 2016 13:07:27 +0300 Subject: [PATCH 084/125] 8157831: JVMCI tests should not be executed on linux-arm32 Reviewed-by: dpochepk, dholmes --- hotspot/test/TEST.ROOT | 10 +++++----- hotspot/test/compiler/cpuflags/TestSSE4Disabled.java | 2 +- .../test/compiler/jvmci/JVM_GetJVMCIRuntimeTest.java | 2 +- .../test/compiler/jvmci/SecurityRestrictionsTest.java | 2 +- .../jvmci/compilerToVM/AllocateCompileIdTest.java | 2 +- .../jvmci/compilerToVM/CanInlineMethodTest.java | 2 +- .../jvmci/compilerToVM/CollectCountersTest.java | 2 +- .../compiler/jvmci/compilerToVM/DebugOutputTest.java | 2 +- .../jvmci/compilerToVM/DisassembleCodeBlobTest.java | 2 +- .../jvmci/compilerToVM/DoNotInlineOrCompileTest.java | 2 +- .../jvmci/compilerToVM/ExecuteInstalledCodeTest.java | 2 +- .../compilerToVM/FindUniqueConcreteMethodTest.java | 2 +- .../compiler/jvmci/compilerToVM/GetBytecodeTest.java | 2 +- .../jvmci/compilerToVM/GetClassInitializerTest.java | 2 +- .../jvmci/compilerToVM/GetConstantPoolTest.java | 2 +- .../jvmci/compilerToVM/GetExceptionTableTest.java | 2 +- .../jvmci/compilerToVM/GetImplementorTest.java | 2 +- .../jvmci/compilerToVM/GetLineNumberTableTest.java | 2 +- .../jvmci/compilerToVM/GetLocalVariableTableTest.java | 2 +- .../jvmci/compilerToVM/GetMaxCallTargetOffsetTest.java | 2 +- .../jvmci/compilerToVM/GetNextStackFrameTest.java | 2 +- .../compilerToVM/GetResolvedJavaMethodAtSlotTest.java | 2 +- .../jvmci/compilerToVM/GetResolvedJavaMethodTest.java | 2 +- .../jvmci/compilerToVM/GetResolvedJavaTypeTest.java | 2 +- .../jvmci/compilerToVM/GetStackTraceElementTest.java | 2 +- .../compiler/jvmci/compilerToVM/GetSymbolTest.java | 2 +- .../compilerToVM/GetVtableIndexForInterfaceTest.java | 2 +- .../jvmci/compilerToVM/HasCompiledCodeForOSRTest.java | 2 +- .../jvmci/compilerToVM/HasFinalizableSubclassTest.java | 2 +- .../compilerToVM/InitializeConfigurationTest.java | 2 +- .../compilerToVM/InvalidateInstalledCodeTest.java | 2 +- .../test/compiler/jvmci/compilerToVM/IsMatureTest.java | 2 +- .../jvmci/compilerToVM/JVM_RegisterJVMCINatives.java | 2 +- .../jvmci/compilerToVM/LookupKlassInPoolTest.java | 2 +- .../compilerToVM/LookupKlassRefIndexInPoolTest.java | 2 +- .../jvmci/compilerToVM/LookupMethodInPoolTest.java | 2 +- .../LookupNameAndTypeRefIndexInPoolTest.java | 2 +- .../jvmci/compilerToVM/LookupNameInPoolTest.java | 2 +- .../jvmci/compilerToVM/LookupSignatureInPoolTest.java | 2 +- .../compiler/jvmci/compilerToVM/LookupTypeTest.java | 2 +- .../compilerToVM/MaterializeVirtualObjectTest.java | 2 +- .../MethodIsIgnoredBySecurityStackWalkTest.java | 2 +- .../compiler/jvmci/compilerToVM/ReprofileTest.java | 2 +- .../jvmci/compilerToVM/ResolveConstantInPoolTest.java | 2 +- .../jvmci/compilerToVM/ResolveFieldInPoolTest.java | 2 +- .../compiler/jvmci/compilerToVM/ResolveMethodTest.java | 2 +- .../ResolvePossiblyCachedConstantInPoolTest.java | 2 +- .../jvmci/compilerToVM/ResolveTypeInPoolTest.java | 2 +- .../compilerToVM/ShouldDebugNonSafepointsTest.java | 2 +- .../jvmci/compilerToVM/ShouldInlineMethodTest.java | 2 +- .../jvmci/errors/TestInvalidCompilationResult.java | 2 +- .../compiler/jvmci/errors/TestInvalidDebugInfo.java | 2 +- .../test/compiler/jvmci/errors/TestInvalidOopMap.java | 2 +- .../events/JvmciNotifyBootstrapFinishedEventTest.java | 2 +- .../jvmci/events/JvmciNotifyInstallEventTest.java | 2 +- .../compiler/jvmci/events/JvmciShutdownEventTest.java | 2 +- .../src/jdk/vm/ci/code/test/DataPatchTest.java | 2 +- .../jdk/vm/ci/code/test/InterpreterFrameSizeTest.java | 2 +- .../vm/ci/code/test/SimpleCodeInstallationTest.java | 2 +- .../src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java | 2 +- .../vm/ci/code/test/VirtualObjectDebugInfoTest.java | 2 +- .../test/HotSpotConstantReflectionProviderTest.java | 2 +- .../vm/ci/hotspot/test/MemoryAccessProviderTest.java | 2 +- .../hotspot/test/MethodHandleAccessProviderTest.java | 2 +- .../src/jdk/vm/ci/runtime/test/ConstantTest.java | 2 +- .../src/jdk/vm/ci/runtime/test/RedefineClassTest.java | 2 +- .../ResolvedJavaTypeResolveConcreteMethodTest.java | 2 +- .../test/ResolvedJavaTypeResolveMethodTest.java | 2 +- .../runtime/test/TestConstantReflectionProvider.java | 2 +- .../src/jdk/vm/ci/runtime/test/TestJavaField.java | 2 +- .../src/jdk/vm/ci/runtime/test/TestJavaMethod.java | 2 +- .../src/jdk/vm/ci/runtime/test/TestJavaType.java | 2 +- .../jdk/vm/ci/runtime/test/TestMetaAccessProvider.java | 2 +- .../jdk/vm/ci/runtime/test/TestResolvedJavaField.java | 2 +- .../jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java | 2 +- .../jdk/vm/ci/runtime/test/TestResolvedJavaType.java | 2 +- hotspot/test/compiler/jvmci/meta/StableFieldTest.java | 2 +- .../runtime/ThreadSignalMask/ThreadSignalMask.java | 2 +- 78 files changed, 82 insertions(+), 82 deletions(-) diff --git a/hotspot/test/TEST.ROOT b/hotspot/test/TEST.ROOT index e52c1b1a3ff..07d50e2e5d4 100644 --- a/hotspot/test/TEST.ROOT +++ b/hotspot/test/TEST.ROOT @@ -1,4 +1,4 @@ -# +# # Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # @@ -19,7 +19,7 @@ # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. -# +# # @@ -31,10 +31,10 @@ keys=cte_test jcmd nmt regression gc stress groups=TEST.groups [closed/TEST.groups] -# Source files for classes that will be used at the beginning of each test suite run, -# to determine additional characteristics of the system for use with the @requires tag. +# Source files for classes that will be used at the beginning of each test suite run, +# to determine additional characteristics of the system for use with the @requires tag. requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java -requires.properties=sun.arch.data.model +requires.properties=sun.arch.data.model vm.simpleArch # Tests using jtreg 4.2 b02 features requiredVersion=4.2 b02 diff --git a/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java b/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java index 4bd655f6cac..2700b9170d7 100644 --- a/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java +++ b/hotspot/test/compiler/cpuflags/TestSSE4Disabled.java @@ -25,7 +25,7 @@ /* * @test TestSSE4Disabled * @bug 8158214 - * @requires (os.simpleArch == "x64") + * @requires (vm.simpleArch == "x64") * @summary Test correct execution without SSE 4. * @run main/othervm -Xcomp -XX:UseSSE=3 TestSSE4Disabled */ diff --git a/hotspot/test/compiler/jvmci/JVM_GetJVMCIRuntimeTest.java b/hotspot/test/compiler/jvmci/JVM_GetJVMCIRuntimeTest.java index 13849452847..57eed059a8d 100644 --- a/hotspot/test/compiler/jvmci/JVM_GetJVMCIRuntimeTest.java +++ b/hotspot/test/compiler/jvmci/JVM_GetJVMCIRuntimeTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary / * @modules java.base/jdk.internal.misc * @modules jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/SecurityRestrictionsTest.java b/hotspot/test/compiler/jvmci/SecurityRestrictionsTest.java index 48c406a4adc..22263a7f837 100644 --- a/hotspot/test/compiler/jvmci/SecurityRestrictionsTest.java +++ b/hotspot/test/compiler/jvmci/SecurityRestrictionsTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/AllocateCompileIdTest.java b/hotspot/test/compiler/jvmci/compilerToVM/AllocateCompileIdTest.java index 148402ee786..daeaaed3360 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/AllocateCompileIdTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/AllocateCompileIdTest.java @@ -24,7 +24,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/CanInlineMethodTest.java b/hotspot/test/compiler/jvmci/compilerToVM/CanInlineMethodTest.java index 4500a83ac56..7a313d4a411 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/CanInlineMethodTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/CanInlineMethodTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/CollectCountersTest.java b/hotspot/test/compiler/jvmci/compilerToVM/CollectCountersTest.java index dc905f3a2ae..8bd98dc05cb 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/CollectCountersTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/CollectCountersTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib/ * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/DebugOutputTest.java b/hotspot/test/compiler/jvmci/compilerToVM/DebugOutputTest.java index ffe0a899cba..477c9128c4e 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/DebugOutputTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/DebugOutputTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/DisassembleCodeBlobTest.java b/hotspot/test/compiler/jvmci/compilerToVM/DisassembleCodeBlobTest.java index d8eedaad0c2..aeb384da0fe 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/DisassembleCodeBlobTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/DisassembleCodeBlobTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/DoNotInlineOrCompileTest.java b/hotspot/test/compiler/jvmci/compilerToVM/DoNotInlineOrCompileTest.java index db741621e2a..a3ab66ac36a 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/DoNotInlineOrCompileTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/DoNotInlineOrCompileTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ExecuteInstalledCodeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ExecuteInstalledCodeTest.java index 399ff0cca73..5ea1bbd8923 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ExecuteInstalledCodeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ExecuteInstalledCodeTest.java @@ -21,7 +21,7 @@ import java.util.Map; /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @ignore 8139383 diff --git a/hotspot/test/compiler/jvmci/compilerToVM/FindUniqueConcreteMethodTest.java b/hotspot/test/compiler/jvmci/compilerToVM/FindUniqueConcreteMethodTest.java index cc5ff3d9e2d..7b237098709 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/FindUniqueConcreteMethodTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/FindUniqueConcreteMethodTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetBytecodeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetBytecodeTest.java index 7bfd132a5e9..a72d0c408a6 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetBytecodeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetBytecodeTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetClassInitializerTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetClassInitializerTest.java index 3f2c80f1642..2eec0dacf1f 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetClassInitializerTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetClassInitializerTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java index c9826c857e3..00be36102ad 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetConstantPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetExceptionTableTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetExceptionTableTest.java index 536972d755a..2d7d5115ac2 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetExceptionTableTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetExceptionTableTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetImplementorTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetImplementorTest.java index 894791f1006..e907eb82d9d 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetImplementorTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetImplementorTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib/ * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetLineNumberTableTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetLineNumberTableTest.java index c1bfbba85ff..c121881154b 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetLineNumberTableTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetLineNumberTableTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @library ../common/patches diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetLocalVariableTableTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetLocalVariableTableTest.java index d6f6725f723..4fb64f71398 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetLocalVariableTableTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetLocalVariableTableTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetMaxCallTargetOffsetTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetMaxCallTargetOffsetTest.java index 93653fd57a0..44574b0455c 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetMaxCallTargetOffsetTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetMaxCallTargetOffsetTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib/ * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetNextStackFrameTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetNextStackFrameTest.java index afca9ec85fb..7809e94c656 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetNextStackFrameTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetNextStackFrameTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodAtSlotTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodAtSlotTest.java index d23aad95fb6..7fc31dea426 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodAtSlotTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodAtSlotTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodTest.java index 6e0fea30328..8353fc5c536 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaMethodTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java index a648caaac67..98b3385c068 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetResolvedJavaTypeTest.java @@ -25,7 +25,7 @@ * @test * @bug 8136421 * @ignore 8158860 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetStackTraceElementTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetStackTraceElementTest.java index 970e8cbfb58..da0feed2ae7 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetStackTraceElementTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetStackTraceElementTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetSymbolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetSymbolTest.java index 7e10c95e0b8..69a45d10185 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetSymbolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetSymbolTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/GetVtableIndexForInterfaceTest.java b/hotspot/test/compiler/jvmci/compilerToVM/GetVtableIndexForInterfaceTest.java index 66a0bd94f7d..163f6bdd095 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/GetVtableIndexForInterfaceTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/GetVtableIndexForInterfaceTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/HasCompiledCodeForOSRTest.java b/hotspot/test/compiler/jvmci/compilerToVM/HasCompiledCodeForOSRTest.java index 9cb947eb7e1..84acf8ccd7b 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/HasCompiledCodeForOSRTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/HasCompiledCodeForOSRTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/HasFinalizableSubclassTest.java b/hotspot/test/compiler/jvmci/compilerToVM/HasFinalizableSubclassTest.java index d972a22dc36..2f4e9214fac 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/HasFinalizableSubclassTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/HasFinalizableSubclassTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java b/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java index 9087b52baf1..2be4348c4f3 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/InvalidateInstalledCodeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/InvalidateInstalledCodeTest.java index 369be8612d1..881e339a495 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/InvalidateInstalledCodeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/InvalidateInstalledCodeTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java b/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java index fe2f0259844..0b1296aac5f 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/JVM_RegisterJVMCINatives.java b/hotspot/test/compiler/jvmci/compilerToVM/JVM_RegisterJVMCINatives.java index 56a43432040..61405cb9f46 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/JVM_RegisterJVMCINatives.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/JVM_RegisterJVMCINatives.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary / * @modules java.base/jdk.internal.misc * @modules jdk.vm.ci/jdk.vm.ci.hotspot diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java index 88629b101a3..54fa2e653d2 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @summary Testing compiler.jvmci.CompilerToVM.lookupKlassInPool method * @library /testlibrary /test/lib / * @library ../common/patches diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java index 87020af5181..260f55387bb 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java index 3b64af7ffea..302b2093123 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java index 4f1cac0fb47..62093cb7d2a 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java index 65f6ec0efdf..7ea7b85c5cd 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java index 391a9dc12f6..98fa85d476b 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupTypeTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupTypeTest.java index 712d5d8b2cf..22fa694e8cf 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupTypeTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupTypeTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/MaterializeVirtualObjectTest.java b/hotspot/test/compiler/jvmci/compilerToVM/MaterializeVirtualObjectTest.java index de107e0d220..9ffd2818e93 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/MaterializeVirtualObjectTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/MaterializeVirtualObjectTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/MethodIsIgnoredBySecurityStackWalkTest.java b/hotspot/test/compiler/jvmci/compilerToVM/MethodIsIgnoredBySecurityStackWalkTest.java index d78672acfaf..cf244d19cc9 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/MethodIsIgnoredBySecurityStackWalkTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/MethodIsIgnoredBySecurityStackWalkTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java index 371af37813d..fded2340074 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java index cd16f512e52..fb0db08ecbf 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java index 8151340f9f8..f0298cdf96e 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveMethodTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveMethodTest.java index 98b56f8cc3c..4ac3c87323a 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveMethodTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveMethodTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java index 6a1cfb7623e..ddec6f92a16 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8138708 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java index 92f7a19b5e0..37ab43922de 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java @@ -25,7 +25,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @summary Testing compiler.jvmci.CompilerToVM.resolveTypeInPool method * @library /testlibrary /test/lib / * @library ../common/patches diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ShouldDebugNonSafepointsTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ShouldDebugNonSafepointsTest.java index a6dd4cfe8a3..1ec2722aa3d 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ShouldDebugNonSafepointsTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ShouldDebugNonSafepointsTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary /test/lib/ * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ShouldInlineMethodTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ShouldInlineMethodTest.java index bef796ab825..ebaf42987a6 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ShouldInlineMethodTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ShouldInlineMethodTest.java @@ -25,7 +25,7 @@ /** * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/errors/TestInvalidCompilationResult.java b/hotspot/test/compiler/jvmci/errors/TestInvalidCompilationResult.java index 75d70e7baa7..bc2eae33f00 100644 --- a/hotspot/test/compiler/jvmci/errors/TestInvalidCompilationResult.java +++ b/hotspot/test/compiler/jvmci/errors/TestInvalidCompilationResult.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code * jdk.vm.ci/jdk.vm.ci.code.site diff --git a/hotspot/test/compiler/jvmci/errors/TestInvalidDebugInfo.java b/hotspot/test/compiler/jvmci/errors/TestInvalidDebugInfo.java index 603b360a480..7beb74f263e 100644 --- a/hotspot/test/compiler/jvmci/errors/TestInvalidDebugInfo.java +++ b/hotspot/test/compiler/jvmci/errors/TestInvalidDebugInfo.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code * jdk.vm.ci/jdk.vm.ci.code.site diff --git a/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java b/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java index 7fe01e55470..1c4b8840140 100644 --- a/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java +++ b/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code * jdk.vm.ci/jdk.vm.ci.code.site diff --git a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java index 20177c3de6c..54d95182792 100644 --- a/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java +++ b/hotspot/test/compiler/jvmci/events/JvmciNotifyBootstrapFinishedEventTest.java @@ -24,7 +24,7 @@ /** * @test * @bug 8156034 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/events/JvmciNotifyInstallEventTest.java b/hotspot/test/compiler/jvmci/events/JvmciNotifyInstallEventTest.java index e045775c7ee..b6c47bfb342 100644 --- a/hotspot/test/compiler/jvmci/events/JvmciNotifyInstallEventTest.java +++ b/hotspot/test/compiler/jvmci/events/JvmciNotifyInstallEventTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library / /testlibrary * @library ../common/patches * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/compiler/jvmci/events/JvmciShutdownEventTest.java b/hotspot/test/compiler/jvmci/events/JvmciShutdownEventTest.java index c5c5a19ddde..744ddc61bd5 100644 --- a/hotspot/test/compiler/jvmci/events/JvmciShutdownEventTest.java +++ b/hotspot/test/compiler/jvmci/events/JvmciShutdownEventTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8136421 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary / * @modules java.base/jdk.internal.misc * @modules jdk.vm.ci/jdk.vm.ci.hotspot diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java index b2070884fc3..5a4680de2fe 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9") & os.arch != "aarch64" * @library / * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java index 098871da3b1..b4b3f44ffe8 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9") & os.arch != "aarch64" * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code * jdk.vm.ci/jdk.vm.ci.code.site diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java index 0b8ca5c19f7..6db85e842e2 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9") & os.arch != "aarch64" * @library / * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java index 13c9d3a9012..057c7acfcda 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9") & os.arch != "aarch64" * @library / * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java index 6c2f5d7ae31..4a4b297e764 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9") & os.arch != "aarch64" * @library / * @modules jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/HotSpotConstantReflectionProviderTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/HotSpotConstantReflectionProviderTest.java index 7cd0502bd5a..1cc6215e729 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/HotSpotConstantReflectionProviderTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/HotSpotConstantReflectionProviderTest.java @@ -23,7 +23,7 @@ /* * @test jdk.vm.ci.hotspot.test.HotSpotConstantReflectionProviderTest - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.hotspot diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java index ed07e8af3a1..466e4e32156 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8152341 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib /compiler/jvmci/jdk.vm.ci.hotspot.test/src * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.common diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java index cf928d20356..dedb1cffcd2 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java @@ -24,7 +24,7 @@ /* * @test * @bug 8152343 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib /compiler/jvmci/jdk.vm.ci.hotspot.test/src * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java index 63230f38955..7857845edf3 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ConstantTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/RedefineClassTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/RedefineClassTest.java index 604d671513b..0cc7a30667c 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/RedefineClassTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/RedefineClassTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveConcreteMethodTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveConcreteMethodTest.java index b253a38f30b..213b7c2fc15 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveConcreteMethodTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveConcreteMethodTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.runtime.test.ResolvedJavaTypeResolveConcreteMethodTest diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveMethodTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveMethodTest.java index 0d8121b3ee7..0d65a36ca33 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveMethodTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/ResolvedJavaTypeResolveMethodTest.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.runtime.test.ResolvedJavaTypeResolveMethodTest diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestConstantReflectionProvider.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestConstantReflectionProvider.java index 824a1532c62..ab6325eda0a 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestConstantReflectionProvider.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestConstantReflectionProvider.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaField.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaField.java index 4537b386de5..8359fb0676d 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaField.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaField.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaMethod.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaMethod.java index faa96b898a6..b143206e6ad 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaMethod.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaMethod.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaType.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaType.java index 23959e2059f..ffcd3b43e8a 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaType.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestJavaType.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java index 8f16a40abb6..16ca94e2d3e 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestMetaAccessProvider.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaField.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaField.java index 3fb08386077..2c3a677a90d 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaField.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaField.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java index d96560ce11f..0a58b4b39fe 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java index 4b06b4b9b29..b30686dfe71 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java @@ -23,7 +23,7 @@ /** * @test - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library ../../../../../ * @modules java.base/jdk.internal.reflect * jdk.vm.ci/jdk.vm.ci.meta diff --git a/hotspot/test/compiler/jvmci/meta/StableFieldTest.java b/hotspot/test/compiler/jvmci/meta/StableFieldTest.java index 5c2bd0d9e2b..c2087a57af8 100644 --- a/hotspot/test/compiler/jvmci/meta/StableFieldTest.java +++ b/hotspot/test/compiler/jvmci/meta/StableFieldTest.java @@ -24,7 +24,7 @@ /** * @test * @bug 8151664 - * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9" | os.simpleArch == "aarch64") + * @requires (vm.simpleArch == "x64" | vm.simpleArch == "sparcv9" | vm.simpleArch == "aarch64") * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.base/jdk.internal.vm.annotation diff --git a/hotspot/test/runtime/ThreadSignalMask/ThreadSignalMask.java b/hotspot/test/runtime/ThreadSignalMask/ThreadSignalMask.java index 1670b02656f..55cee37ae31 100644 --- a/hotspot/test/runtime/ThreadSignalMask/ThreadSignalMask.java +++ b/hotspot/test/runtime/ThreadSignalMask/ThreadSignalMask.java @@ -35,7 +35,7 @@ import jdk.test.lib.Asserts; * @key cte_test * @bug 4345157 * @summary JDK 1.3.0 alters thread signal mask - * @requires (os.simpleArch == "sparcv9") + * @requires (vm.simpleArch == "sparcv9") * @modules java.base/jdk.internal.misc * @library /testlibrary * @compile Prog.java From 36ac8c8a004fc3050500ed2a1c8ce232ae50b8c6 Mon Sep 17 00:00:00 2001 From: Rachel Protacio Date: Fri, 17 Jun 2016 10:46:55 -0400 Subject: [PATCH 085/125] 8153394: Add Unified Logging to make it easy to trace time taken in initPhase2 Added modules+startuptime logging for initPhase2 via TraceTime class Reviewed-by: rehn, hseigel, mockner --- hotspot/src/share/vm/runtime/thread.cpp | 2 ++ .../test/runtime/logging/StartupTimeTest.java | 20 +++++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index 91d2ed4aa0c..a3f0561c93a 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -3405,6 +3405,8 @@ static void call_initPhase1(TRAPS) { // // After phase 2, The VM will begin search classes from -Xbootclasspath/a. static void call_initPhase2(TRAPS) { + TraceTime timer("Phase2 initialization", TRACETIME_LOG(Info, modules, startuptime)); + Klass* k = SystemDictionary::resolve_or_fail(vmSymbols::java_lang_System(), true, CHECK); instanceKlassHandle klass (THREAD, k); diff --git a/hotspot/test/runtime/logging/StartupTimeTest.java b/hotspot/test/runtime/logging/StartupTimeTest.java index 3e65b1d9510..1c5a77e8730 100644 --- a/hotspot/test/runtime/logging/StartupTimeTest.java +++ b/hotspot/test/runtime/logging/StartupTimeTest.java @@ -50,6 +50,18 @@ public class StartupTimeTest { output.shouldHaveExitValue(0); } + static void analyzeModulesOutputOn(ProcessBuilder pb) throws Exception { + OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldMatch("(Phase2 initialization, [0-9]+.[0-9]+ secs)"); + output.shouldHaveExitValue(0); + } + + static void analyzeModulesOutputOff(ProcessBuilder pb) throws Exception { + OutputAnalyzer output = new OutputAnalyzer(pb.start()); + output.shouldNotContain("[modules,startuptime]"); + output.shouldHaveExitValue(0); + } + public static void main(String[] args) throws Exception { ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xlog:startuptime", InnerClass.class.getName()); @@ -58,6 +70,14 @@ public class StartupTimeTest { pb = ProcessTools.createJavaProcessBuilder("-Xlog:startuptime=off", InnerClass.class.getName()); analyzeOutputOff(pb); + + pb = ProcessTools.createJavaProcessBuilder("-Xlog:startuptime+modules", + InnerClass.class.getName()); + analyzeModulesOutputOn(pb); + + pb = ProcessTools.createJavaProcessBuilder("-Xlog:startuptime+modules=off", + InnerClass.class.getName()); + analyzeModulesOutputOff(pb); } public static class InnerClass { From 4dd736d71a0f0427a6c9d32fc5e5f29936e7f78f Mon Sep 17 00:00:00 2001 From: Michail Chernov Date: Fri, 17 Jun 2016 18:45:09 +0300 Subject: [PATCH 086/125] 8158412: [TESTBUG] TestIHOPErgo and TestStressG1Humongous should not be executed when JFR is enabled Reviewed-by: dfazunen, tschatzl --- hotspot/test/TEST.ROOT | 2 +- hotspot/test/gc/g1/ihop/TestIHOPErgo.java | 4 ++-- hotspot/test/gc/g1/ihop/TestIHOPStatic.java | 4 ++-- hotspot/test/gc/g1/plab/TestPLABPromotion.java | 4 ++-- hotspot/test/gc/g1/plab/TestPLABResize.java | 4 ++-- hotspot/test/gc/stress/TestStressG1Humongous.java | 3 ++- 6 files changed, 11 insertions(+), 10 deletions(-) diff --git a/hotspot/test/TEST.ROOT b/hotspot/test/TEST.ROOT index 07d50e2e5d4..00a177ae6b4 100644 --- a/hotspot/test/TEST.ROOT +++ b/hotspot/test/TEST.ROOT @@ -34,7 +34,7 @@ groups=TEST.groups [closed/TEST.groups] # Source files for classes that will be used at the beginning of each test suite run, # to determine additional characteristics of the system for use with the @requires tag. requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java -requires.properties=sun.arch.data.model vm.simpleArch +requires.properties=sun.arch.data.model vm.simpleArch vm.flightRecorder # Tests using jtreg 4.2 b02 features requiredVersion=4.2 b02 diff --git a/hotspot/test/gc/g1/ihop/TestIHOPErgo.java b/hotspot/test/gc/g1/ihop/TestIHOPErgo.java index f77d4584fa9..0332844da07 100644 --- a/hotspot/test/gc/g1/ihop/TestIHOPErgo.java +++ b/hotspot/test/gc/g1/ihop/TestIHOPErgo.java @@ -25,8 +25,8 @@ * @test TestIHOPErgo * @bug 8148397 * @summary Test checks that behavior of Adaptive and Static IHOP at concurrent cycle initiation - * @requires vm.gc=="G1" | vm.gc=="null" - * @requires vm.opt.FlightRecorder != true + * @requires vm.gc == "G1" | vm.gc == "null" + * @requires !vm.flightRecorder * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @requires vm.opt.MaxGCPauseMillis == "null" * @library /testlibrary /test/lib / diff --git a/hotspot/test/gc/g1/ihop/TestIHOPStatic.java b/hotspot/test/gc/g1/ihop/TestIHOPStatic.java index efbe6d6ab69..7fc78cf80fc 100644 --- a/hotspot/test/gc/g1/ihop/TestIHOPStatic.java +++ b/hotspot/test/gc/g1/ihop/TestIHOPStatic.java @@ -25,8 +25,8 @@ * @test TestIHOPStatic * @bug 8148397 * @summary Test checks concurrent cycle initiation which depends on IHOP value. - * @requires vm.gc=="G1" | vm.gc=="null" - * @requires vm.opt.FlightRecorder != true + * @requires vm.gc == "G1" | vm.gc == "null" + * @requires !vm.flightRecorder * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @library /testlibrary / * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/plab/TestPLABPromotion.java b/hotspot/test/gc/g1/plab/TestPLABPromotion.java index cefff072c32..0f4a84c5104 100644 --- a/hotspot/test/gc/g1/plab/TestPLABPromotion.java +++ b/hotspot/test/gc/g1/plab/TestPLABPromotion.java @@ -25,8 +25,8 @@ * @test TestPLABPromotion * @bug 8141278 8141141 * @summary Test PLAB promotion - * @requires vm.gc=="G1" | vm.gc=="null" - * @requires vm.opt.FlightRecorder != true + * @requires vm.gc == "G1" | vm.gc == "null" + * @requires !vm.flightRecorder * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/plab/TestPLABResize.java b/hotspot/test/gc/g1/plab/TestPLABResize.java index 039ef53e8ed..b065abb57e5 100644 --- a/hotspot/test/gc/g1/plab/TestPLABResize.java +++ b/hotspot/test/gc/g1/plab/TestPLABResize.java @@ -25,8 +25,8 @@ * @test TestPLABResize * @bug 8141278 8141141 * @summary Test for PLAB resizing - * @requires vm.gc=="G1" | vm.gc=="null" - * @requires vm.opt.FlightRecorder != true + * @requires vm.gc == "G1" | vm.gc == "null" + * @requires !vm.flightRecorder * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/stress/TestStressG1Humongous.java b/hotspot/test/gc/stress/TestStressG1Humongous.java index 91a5f06a421..de9e1be4555 100644 --- a/hotspot/test/gc/stress/TestStressG1Humongous.java +++ b/hotspot/test/gc/stress/TestStressG1Humongous.java @@ -26,7 +26,8 @@ * @key gc * @key stress * @summary Stress G1 by humongous allocations in situation near OOM - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc == "G1" | vm.gc == "null" + * @requires !vm.flightRecorder * @run main/othervm/timeout=200 -Xlog:gc=debug -Xmx1g -XX:+UseG1GC -XX:G1HeapRegionSize=4m * -Dtimeout=120 -Dthreads=3 -Dhumongoussize=1.1 -Dregionsize=4 TestStressG1Humongous * @run main/othervm/timeout=200 -Xlog:gc=debug -Xmx1g -XX:+UseG1GC -XX:G1HeapRegionSize=16m From 59e24cdba0d8d9c744bbc9b325f74d425eb0a37c Mon Sep 17 00:00:00 2001 From: Michail Chernov Date: Fri, 17 Jun 2016 18:45:24 +0300 Subject: [PATCH 087/125] 8158412: [TESTBUG] TestIHOPErgo and TestStressG1Humongous should not be executed when JFR is enabled Reviewed-by: dfazunen, tschatzl --- test/jtreg-ext/requires/VMProps.java | 30 +++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/test/jtreg-ext/requires/VMProps.java b/test/jtreg-ext/requires/VMProps.java index 468868a7989..7bb67f32828 100644 --- a/test/jtreg-ext/requires/VMProps.java +++ b/test/jtreg-ext/requires/VMProps.java @@ -23,6 +23,8 @@ package requires; import java.io.IOException; +import java.lang.management.ManagementFactory; +import java.lang.management.RuntimeMXBean; import java.nio.file.Files; import java.nio.file.Paths; import java.util.ArrayList; @@ -52,6 +54,7 @@ public class VMProps implements Callable> { map.put("vm.flavor", vmFlavor()); map.put("vm.compMode", vmCompMode()); map.put("vm.bits", vmBits()); + map.put("vm.flightRecorder", vmFlightRecorder()); map.put("vm.simpleArch", vmArch()); dump(map); return map; @@ -122,6 +125,27 @@ public class VMProps implements Callable> { return System.getProperty("sun.arch.data.model"); } + /** + * @return "true" if Flight Recorder is enabled, "false" if is disabled. + */ + protected String vmFlightRecorder() { + RuntimeMXBean runtimeMxBean = ManagementFactory.getRuntimeMXBean(); + List arguments = runtimeMxBean.getInputArguments(); + if (arguments.contains("-XX:+UnlockCommercialFeatures")) { + if (arguments.contains("-XX:+FlightRecorder")) { + return "true"; + } + if (arguments.contains("-XX:-FlightRecorder")) { + return "false"; + } + if (arguments.stream() + .anyMatch(option -> option.startsWith("-XX:StartFlightRecording"))) { + return "true"; + } + } + return "false"; + } + /** * Dumps the map to the file if the file name is given as the property. * This functionality could be helpful to know context in the real @@ -135,9 +159,9 @@ public class VMProps implements Callable> { return; } List lines = new ArrayList<>(); - map.forEach((k,v) -> lines.add(k + ":" + v)); + map.forEach((k, v) -> lines.add(k + ":" + v)); try { - Files.write(Paths.get(dumpFileName), lines); + Files.write(Paths.get(dumpFileName), lines); } catch (IOException e) { throw new RuntimeException("Failed to dump properties into '" + dumpFileName + "'", e); @@ -150,6 +174,6 @@ public class VMProps implements Callable> { */ public static void main(String args[]) { Map map = new VMProps().call(); - map.forEach((k,v) -> System.out.println(k + ": '" + v + "'")); + map.forEach((k, v) -> System.out.println(k + ": '" + v + "'")); } } From 07a914f5bd4b01b95047dc1239152fb8937d4b57 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Tue, 28 Jun 2016 14:20:17 +0200 Subject: [PATCH 088/125] 8160285: Bootcycle builds are broken on jdk9/hs for windows i586 Reviewed-by: dholmes --- common/autoconf/boot-jdk.m4 | 52 +++++++++++++++-------- common/autoconf/bootcycle-spec.gmk.in | 2 + common/autoconf/generated-configure.sh | 57 ++++++++++++++++++-------- 3 files changed, 78 insertions(+), 33 deletions(-) diff --git a/common/autoconf/boot-jdk.m4 b/common/autoconf/boot-jdk.m4 index 77b5b38f4b6..1aded9e4486 100644 --- a/common/autoconf/boot-jdk.m4 +++ b/common/autoconf/boot-jdk.m4 @@ -359,25 +359,32 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], # Starting amount of heap memory. ADD_JVM_ARG_IF_OK([-Xms64M],boot_jdk_jvmargs_big,[$JAVA]) + BOOTCYCLE_JVM_ARGS_BIG=-Xms64M + + # Maximum amount of heap memory and stack size. + JVM_HEAP_LIMIT_32="1100" + # Running a 64 bit JVM allows for and requires a bigger heap + JVM_HEAP_LIMIT_64="1600" + STACK_SIZE_32=768 + STACK_SIZE_64=1536 + JVM_HEAP_LIMIT_GLOBAL=`expr $MEMORY_SIZE / 2` + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "$JVM_HEAP_LIMIT_32"; then + JVM_HEAP_LIMIT_32=$JVM_HEAP_LIMIT_GLOBAL + fi + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "$JVM_HEAP_LIMIT_64"; then + JVM_HEAP_LIMIT_64=$JVM_HEAP_LIMIT_GLOBAL + fi + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "512"; then + JVM_HEAP_LIMIT_32=512 + JVM_HEAP_LIMIT_64=512 + fi - # Maximum amount of heap memory. - # Maximum stack size. - JVM_MAX_HEAP=`expr $MEMORY_SIZE / 2` if test "x$BOOT_JDK_BITS" = "x32"; then - if test "$JVM_MAX_HEAP" -gt "1100"; then - JVM_MAX_HEAP=1100 - elif test "$JVM_MAX_HEAP" -lt "512"; then - JVM_MAX_HEAP=512 - fi - STACK_SIZE=768 + STACK_SIZE=$STACK_SIZE_32 + JVM_MAX_HEAP=$JVM_HEAP_LIMIT_32 else - # Running a 64 bit JVM allows for and requires a bigger heap - if test "$JVM_MAX_HEAP" -gt "1600"; then - JVM_MAX_HEAP=1600 - elif test "$JVM_MAX_HEAP" -lt "512"; then - JVM_MAX_HEAP=512 - fi - STACK_SIZE=1536 + STACK_SIZE=$STACK_SIZE_64 + JVM_MAX_HEAP=$JVM_HEAP_LIMIT_64 fi ADD_JVM_ARG_IF_OK([-Xmx${JVM_MAX_HEAP}M],boot_jdk_jvmargs_big,[$JAVA]) ADD_JVM_ARG_IF_OK([-XX:ThreadStackSize=$STACK_SIZE],boot_jdk_jvmargs_big,[$JAVA]) @@ -387,6 +394,19 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], JAVA_FLAGS_BIG=$boot_jdk_jvmargs_big AC_SUBST(JAVA_FLAGS_BIG) + if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then + BOOTCYCLE_MAX_HEAP=$JVM_HEAP_LIMIT_32 + BOOTCYCLE_STACK_SIZE=$STACK_SIZE_32 + else + BOOTCYCLE_MAX_HEAP=$JVM_HEAP_LIMIT_64 + BOOTCYCLE_STACK_SIZE=$STACK_SIZE_64 + fi + BOOTCYCLE_JVM_ARGS_BIG="$BOOTCYCLE_JVM_ARGS_BIG -Xmx${BOOTCYCLE_MAX_HEAP}M" + BOOTCYCLE_JVM_ARGS_BIG="$BOOTCYCLE_JVM_ARGS_BIG -XX:ThreadStackSize=$BOOTCYCLE_STACK_SIZE" + AC_MSG_CHECKING([flags for bootcycle boot jdk java command for big workloads]) + AC_MSG_RESULT([$BOOTCYCLE_JVM_ARGS_BIG]) + AC_SUBST(BOOTCYCLE_JVM_ARGS_BIG) + # By default, the main javac compilations use big JAVA_FLAGS_JAVAC="$JAVA_FLAGS_BIG" AC_SUBST(JAVA_FLAGS_JAVAC) diff --git a/common/autoconf/bootcycle-spec.gmk.in b/common/autoconf/bootcycle-spec.gmk.in index c37097d1b1d..aa722761939 100644 --- a/common/autoconf/bootcycle-spec.gmk.in +++ b/common/autoconf/bootcycle-spec.gmk.in @@ -66,3 +66,5 @@ SJAVAC_SERVER_JAVA_CMD:=$(JAVA_CMD) ifeq ($(OPENJDK_TARGET_CPU_BITS), 32) SJAVAC_SERVER_JAVA_FLAGS:= -Xms256M -Xmx1500M endif +# The bootcycle JVM arguments may differ from the original boot jdk. +JAVA_FLAGS_BIG := @BOOTCYCLE_JVM_ARGS_BIG@ diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 525a890bae3..049b8936829 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -644,6 +644,7 @@ SJAVAC_SERVER_JAVA JAVA_TOOL_FLAGS_SMALL JAVA_FLAGS_SMALL JAVA_FLAGS_JAVAC +BOOTCYCLE_JVM_ARGS_BIG JAVA_FLAGS_BIG JAVA_FLAGS TEST_JOBS @@ -5094,7 +5095,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1467039751 +DATE_WHEN_GENERATED=1467116399 ############################################################################### # @@ -65118,25 +65119,32 @@ $as_echo_n "checking flags for boot jdk java command for big workloads... " >&6; JVM_ARG_OK=false fi + BOOTCYCLE_JVM_ARGS_BIG=-Xms64M + + # Maximum amount of heap memory and stack size. + JVM_HEAP_LIMIT_32="1100" + # Running a 64 bit JVM allows for and requires a bigger heap + JVM_HEAP_LIMIT_64="1600" + STACK_SIZE_32=768 + STACK_SIZE_64=1536 + JVM_HEAP_LIMIT_GLOBAL=`expr $MEMORY_SIZE / 2` + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "$JVM_HEAP_LIMIT_32"; then + JVM_HEAP_LIMIT_32=$JVM_HEAP_LIMIT_GLOBAL + fi + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "$JVM_HEAP_LIMIT_64"; then + JVM_HEAP_LIMIT_64=$JVM_HEAP_LIMIT_GLOBAL + fi + if test "$JVM_HEAP_LIMIT_GLOBAL" -lt "512"; then + JVM_HEAP_LIMIT_32=512 + JVM_HEAP_LIMIT_64=512 + fi - # Maximum amount of heap memory. - # Maximum stack size. - JVM_MAX_HEAP=`expr $MEMORY_SIZE / 2` if test "x$BOOT_JDK_BITS" = "x32"; then - if test "$JVM_MAX_HEAP" -gt "1100"; then - JVM_MAX_HEAP=1100 - elif test "$JVM_MAX_HEAP" -lt "512"; then - JVM_MAX_HEAP=512 - fi - STACK_SIZE=768 + STACK_SIZE=$STACK_SIZE_32 + JVM_MAX_HEAP=$JVM_HEAP_LIMIT_32 else - # Running a 64 bit JVM allows for and requires a bigger heap - if test "$JVM_MAX_HEAP" -gt "1600"; then - JVM_MAX_HEAP=1600 - elif test "$JVM_MAX_HEAP" -lt "512"; then - JVM_MAX_HEAP=512 - fi - STACK_SIZE=1536 + STACK_SIZE=$STACK_SIZE_64 + JVM_MAX_HEAP=$JVM_HEAP_LIMIT_64 fi $ECHO "Check if jvm arg is ok: -Xmx${JVM_MAX_HEAP}M" >&5 @@ -65175,6 +65183,21 @@ $as_echo "$boot_jdk_jvmargs_big" >&6; } JAVA_FLAGS_BIG=$boot_jdk_jvmargs_big + if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then + BOOTCYCLE_MAX_HEAP=$JVM_HEAP_LIMIT_32 + BOOTCYCLE_STACK_SIZE=$STACK_SIZE_32 + else + BOOTCYCLE_MAX_HEAP=$JVM_HEAP_LIMIT_64 + BOOTCYCLE_STACK_SIZE=$STACK_SIZE_64 + fi + BOOTCYCLE_JVM_ARGS_BIG="$BOOTCYCLE_JVM_ARGS_BIG -Xmx${BOOTCYCLE_MAX_HEAP}M" + BOOTCYCLE_JVM_ARGS_BIG="$BOOTCYCLE_JVM_ARGS_BIG -XX:ThreadStackSize=$BOOTCYCLE_STACK_SIZE" + { $as_echo "$as_me:${as_lineno-$LINENO}: checking flags for bootcycle boot jdk java command for big workloads" >&5 +$as_echo_n "checking flags for bootcycle boot jdk java command for big workloads... " >&6; } + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $BOOTCYCLE_JVM_ARGS_BIG" >&5 +$as_echo "$BOOTCYCLE_JVM_ARGS_BIG" >&6; } + + # By default, the main javac compilations use big JAVA_FLAGS_JAVAC="$JAVA_FLAGS_BIG" From 43e27faa9f12942e7a6a4a853a9c0d1a33f702f2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hannes=20Walln=C3=B6fer?= Date: Tue, 28 Jun 2016 15:17:51 +0200 Subject: [PATCH 089/125] 8160435: Source.baseURL is slow for URLs with unregistered protocol Reviewed-by: sundar --- .../jdk/nashorn/internal/runtime/Source.java | 33 ++++++++----------- 1 file changed, 14 insertions(+), 19 deletions(-) diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java index 2331ce12bce..f118bcd2283 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java @@ -36,6 +36,7 @@ import java.io.PrintWriter; import java.io.Reader; import java.lang.ref.WeakReference; import java.net.MalformedURLException; +import java.net.URI; import java.net.URISyntaxException; import java.net.URL; import java.net.URLConnection; @@ -75,8 +76,8 @@ public final class Source implements Loggable { private final String name; /** - * Base directory the File or base part of the URL. Used to implement __DIR__. - * Used to load scripts relative to the 'directory' or 'base' URL of current script. + * Base path or URL of this source. Used to implement __DIR__, which can be + * used to load scripts relative to the location of the current script. * This will be null when it can't be computed. */ private final String base; @@ -875,31 +876,25 @@ public final class Source implements Loggable { } /** - * Get the base url. This is currently used for testing only + * Returns the base directory or URL for the given URL. Used to implement __DIR__. * @param url a URL - * @return base URL for url + * @return base path or URL, or null if argument is not a hierarchical URL */ public static String baseURL(final URL url) { - if (url.getProtocol().equals("file")) { - try { - final Path path = Paths.get(url.toURI()); + try { + final URI uri = url.toURI(); + + if (uri.getScheme().equals("file")) { + final Path path = Paths.get(uri); final Path parent = path.getParent(); return (parent != null) ? (parent + File.separator) : null; - } catch (final SecurityException | URISyntaxException | IOError e) { + } + if (uri.isOpaque() || uri.getPath() == null || uri.getPath().isEmpty()) { return null; } - } + return uri.resolve("").toString(); - // FIXME: is there a better way to find 'base' URL of a given URL? - String path = url.getPath(); - if (path.isEmpty()) { - return null; - } - path = path.substring(0, path.lastIndexOf('/') + 1); - final int port = url.getPort(); - try { - return new URL(url.getProtocol(), url.getHost(), port, path).toString(); - } catch (final MalformedURLException e) { + } catch (final SecurityException | URISyntaxException | IOError e) { return null; } } From 120b177a47b75e879c3bc3ebeb096e2493c681a1 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Tue, 28 Jun 2016 16:04:03 +0200 Subject: [PATCH 090/125] 8160423: Serieal build is broken because of missing dependencies for jmod Reviewed-by: erikj --- make/Main.gmk | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/make/Main.gmk b/make/Main.gmk index 7962a49722c..8c9bd9e5676 100644 --- a/make/Main.gmk +++ b/make/Main.gmk @@ -633,7 +633,9 @@ else # Jmods cannot be created until we have the jlink tool ready to run, which requires # all java modules to be compiled and jdk.jlink-launchers. - $(JMOD_TARGETS): java.base-libs jdk.jlink-launchers + # And we also need to copy jvm.cfg (done in java.base-copy) and tzdb.dat (done in + # java.base-gendata) to the appropriate location otherwise jimage, jlink and jmod won't start. + $(JMOD_TARGETS): java.base-libs java.base-copy java.base-gendata jdk.jlink-launchers # When creating a BUILDJDK, the java compilation has already been done by the # normal build and copied in. ifneq ($(CREATING_BUILDJDK), true) From 50623e2781d23ce9a12e01f01159df823961c7c9 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Wed, 29 Jun 2016 10:07:15 +0200 Subject: [PATCH 091/125] 8160457: VersionProps.versionNumbers() is broken Reviewed-by: redestad, mchung, iris --- .../share/classes/java/lang/VersionProps.java.template | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template b/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template index c5e7b754e6d..a9f12e708ff 100644 --- a/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template +++ b/jdk/src/java.base/share/classes/java/lang/VersionProps.java.template @@ -74,7 +74,7 @@ class VersionProps { while (index > 0) { versionNumbers.add( Integer.parseInt(VERSION_NUMBER, prevIndex, index, 10)); - prevIndex = index; + prevIndex = index + 1; // Skip the period index = VERSION_NUMBER.indexOf('.', prevIndex); } versionNumbers.add(Integer.parseInt(VERSION_NUMBER, From 27036a761faf88f27a34f6d986e3c2757e790313 Mon Sep 17 00:00:00 2001 From: Pavel Rappo Date: Wed, 29 Jun 2016 10:19:48 +0100 Subject: [PATCH 092/125] 8160218: HPack decoder fails when processing header in multiple ByteBuffers Reviewed-by: michaelm --- .../java/net/http/Http2Connection.java | 2 +- .../net/httpclient/hpack/StringReader.java | 2 + .../sun/net/httpclient/hpack/DecoderTest.java | 94 +++++++++++++++++++ .../sun/net/httpclient/hpack/EncoderTest.java | 73 +++++++++++++- 4 files changed, 168 insertions(+), 3 deletions(-) diff --git a/jdk/src/java.httpclient/share/classes/java/net/http/Http2Connection.java b/jdk/src/java.httpclient/share/classes/java/net/http/Http2Connection.java index 780322f4b44..a648679c818 100644 --- a/jdk/src/java.httpclient/share/classes/java/net/http/Http2Connection.java +++ b/jdk/src/java.httpclient/share/classes/java/net/http/Http2Connection.java @@ -298,7 +298,7 @@ class Http2Connection implements BufferHandler { ByteBuffer[] buffers = frame.getHeaderBlock(); for (int i = 0; i < buffers.length; i++) { - hpackIn.decode(buffers[i], endOfHeaders, decoder); + hpackIn.decode(buffers[i], endOfHeaders && (i == buffers.length - 1), decoder); } } diff --git a/jdk/src/java.httpclient/share/classes/sun/net/httpclient/hpack/StringReader.java b/jdk/src/java.httpclient/share/classes/sun/net/httpclient/hpack/StringReader.java index e2bbefb1473..ff3bb67fbbd 100644 --- a/jdk/src/java.httpclient/share/classes/sun/net/httpclient/hpack/StringReader.java +++ b/jdk/src/java.httpclient/share/classes/sun/net/httpclient/hpack/StringReader.java @@ -78,6 +78,7 @@ final class StringReader { if (isLast) { input.limit(input.position() + remainingLength); } + remainingLength -= Math.min(input.remaining(), remainingLength); if (huffman) { huffmanReader.read(input, output, isLast); } else { @@ -85,6 +86,7 @@ final class StringReader { } if (isLast) { input.limit(oldLimit); + state = DONE; } return isLast; } diff --git a/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/DecoderTest.java b/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/DecoderTest.java index 29a651fb0f7..90551a3bb49 100644 --- a/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/DecoderTest.java +++ b/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/DecoderTest.java @@ -27,14 +27,20 @@ import org.testng.annotations.Test; import java.io.UncheckedIOException; import java.net.ProtocolException; import java.nio.ByteBuffer; +import java.util.Iterator; import java.util.LinkedList; import java.util.List; +import java.util.function.Supplier; import java.util.stream.Collectors; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertNotNull; import static sun.net.httpclient.hpack.TestHelper.*; +// +// Tests whose names start with "testX" are the ones captured from real HPACK +// use cases +// public final class DecoderTest { // @@ -138,6 +144,23 @@ public final class DecoderTest { // @formatter:on } + @Test + public void example5AllSplits() { + // @formatter:off + testAllSplits( + "8286 8441 0f77 7777 2e65 7861 6d70 6c65\n" + + "2e63 6f6d", + + "[ 1] (s = 57) :authority: www.example.com\n" + + " Table size: 57", + + ":method: GET\n" + + ":scheme: http\n" + + ":path: /\n" + + ":authority: www.example.com"); + // @formatter:on + } + // // http://tools.ietf.org/html/rfc7541#appendix-C.4 // @@ -334,6 +357,45 @@ public final class DecoderTest { // @formatter:on } + @Test + public void testX1() { + // Supplier of a decoder with a particular state + Supplier s = () -> { + Decoder d = new Decoder(4096); + // @formatter:off + test(d, "88 76 92 ca 54 a7 d7 f4 fa ec af ed 6d da 61 d7 bb 1e ad ff" + + "df 61 97 c3 61 be 94 13 4a 65 b6 a5 04 00 b8 a0 5a b8 db 77" + + "1b 71 4c 5a 37 ff 0f 0d 84 08 00 00 03", + + "[ 1] (s = 65) date: Fri, 24 Jun 2016 14:55:56 GMT\n" + + "[ 2] (s = 59) server: Jetty(9.3.z-SNAPSHOT)\n" + + " Table size: 124", + + ":status: 200\n" + + "server: Jetty(9.3.z-SNAPSHOT)\n" + + "date: Fri, 24 Jun 2016 14:55:56 GMT\n" + + "content-length: 100000" + ); + // @formatter:on + return d; + }; + // For all splits of the following data fed to the supplied decoder we + // must get what's expected + // @formatter:off + testAllSplits(s, + "88 bf be 0f 0d 84 08 00 00 03", + + "[ 1] (s = 65) date: Fri, 24 Jun 2016 14:55:56 GMT\n" + + "[ 2] (s = 59) server: Jetty(9.3.z-SNAPSHOT)\n" + + " Table size: 124", + + ":status: 200\n" + + "server: Jetty(9.3.z-SNAPSHOT)\n" + + "date: Fri, 24 Jun 2016 14:55:56 GMT\n" + + "content-length: 100000"); + // @formatter:on + } + // // This test is missing in the spec // @@ -567,6 +629,38 @@ public final class DecoderTest { test(new Decoder(4096), hexdump, headerTable, headerList); } + private static void testAllSplits(String hexdump, + String expectedHeaderTable, + String expectedHeaderList) { + testAllSplits(() -> new Decoder(256), hexdump, expectedHeaderTable, expectedHeaderList); + } + + private static void testAllSplits(Supplier supplier, String hexdump, + String expectedHeaderTable, String expectedHeaderList) { + ByteBuffer source = SpecHelper.toBytes(hexdump); + + BuffersTestingKit.forEachSplit(source, iterable -> { + List actual = new LinkedList<>(); + Iterator i = iterable.iterator(); + if (!i.hasNext()) { + return; + } + Decoder d = supplier.get(); + do { + ByteBuffer n = i.next(); + d.decode(n, !i.hasNext(), (name, value) -> { + if (value == null) { + actual.add(name.toString()); + } else { + actual.add(name + ": " + value); + } + }); + } while (i.hasNext()); + assertEquals(d.getTable().getStateString(), expectedHeaderTable); + assertEquals(actual.stream().collect(Collectors.joining("\n")), expectedHeaderList); + }); + } + // // Sometimes we need to keep the same decoder along several runs, // as it models the same connection diff --git a/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/EncoderTest.java b/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/EncoderTest.java index c7b375b1238..e9aeceba73b 100644 --- a/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/EncoderTest.java +++ b/jdk/test/java/net/httpclient/http2/java.httpclient/sun/net/httpclient/hpack/EncoderTest.java @@ -24,17 +24,23 @@ package sun.net.httpclient.hpack; import org.testng.annotations.Test; +import java.nio.Buffer; import java.nio.ByteBuffer; import java.util.ArrayList; import java.util.Collections; +import java.util.Iterator; +import java.util.LinkedList; import java.util.List; +import java.util.function.Consumer; import java.util.function.Function; +import static sun.net.httpclient.hpack.BuffersTestingKit.concat; +import static sun.net.httpclient.hpack.BuffersTestingKit.forEachSplit; +import static sun.net.httpclient.hpack.SpecHelper.toHexdump; +import static sun.net.httpclient.hpack.TestHelper.assertVoidThrows; import static java.util.Arrays.asList; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertTrue; -import static sun.net.httpclient.hpack.SpecHelper.toHexdump; -import static sun.net.httpclient.hpack.TestHelper.assertVoidThrows; // TODO: map textual representation of commands from the spec to actual // calls to encoder (actually, this is a good idea for decoder as well) @@ -198,6 +204,61 @@ public final class EncoderTest { // @formatter:on } + @Test + public void example5AllSplits() { + + List> actions = new LinkedList<>(); + actions.add(e -> e.indexed(2)); + actions.add(e -> e.indexed(6)); + actions.add(e -> e.indexed(4)); + actions.add(e -> e.literalWithIndexing(1, "www.example.com", false)); + + encodeAllSplits( + actions, + + "8286 8441 0f77 7777 2e65 7861 6d70 6c65\n" + + "2e63 6f6d", + + "[ 1] (s = 57) :authority: www.example.com\n" + + " Table size: 57"); + } + + private static void encodeAllSplits(Iterable> consumers, + String expectedHexdump, + String expectedTableState) { + ByteBuffer buffer = SpecHelper.toBytes(expectedHexdump); + erase(buffer); // Zeroed buffer of size needed to hold the encoding + forEachSplit(buffer, iterable -> { + List copy = new LinkedList<>(); + iterable.forEach(b -> copy.add(ByteBuffer.allocate(b.remaining()))); + Iterator output = copy.iterator(); + if (!output.hasNext()) { + throw new IllegalStateException("No buffers to encode to"); + } + Encoder e = newCustomEncoder(256); // FIXME: pull up (as a parameter) + drainInitialUpdate(e); + boolean encoded; + ByteBuffer b = output.next(); + for (Consumer c : consumers) { + c.accept(e); + do { + encoded = e.encode(b); + if (!encoded) { + if (output.hasNext()) { + b = output.next(); + } else { + throw new IllegalStateException("No room for encoding"); + } + } + } + while (!encoded); + } + copy.forEach(Buffer::flip); + ByteBuffer data = concat(copy); + test(e, data, expectedHexdump, expectedTableState); + }); + } + // // http://tools.ietf.org/html/rfc7541#appendix-C.4 // @@ -620,4 +681,12 @@ public final class EncoderTest { b.flip(); } while (!done); } + + private static void erase(ByteBuffer buffer) { + buffer.clear(); + while (buffer.hasRemaining()) { + buffer.put((byte) 0); + } + buffer.clear(); + } } From 08a72f828618e878fb26bb062404b83c4016f410 Mon Sep 17 00:00:00 2001 From: Tim Bell Date: Wed, 29 Jun 2016 07:35:59 -0700 Subject: [PATCH 093/125] 8160505: Automated test runs fail in nashorn because TEST_IMAGE_DIR is set by jib Reviewed-by: erikj, sundar --- nashorn/test/Makefile | 13 ------------- 1 file changed, 13 deletions(-) diff --git a/nashorn/test/Makefile b/nashorn/test/Makefile index ee2b87439e8..00e2e8649ef 100644 --- a/nashorn/test/Makefile +++ b/nashorn/test/Makefile @@ -118,19 +118,6 @@ ifdef JPRT_PRODUCT_VM_ARGS JAVA_VM_ARGS = $(JPRT_PRODUCT_VM_ARGS) endif -# jtreg -nativepath -# -# Local make tests will be TEST_IMAGE_DIR and JPRT with jprt.use.reg.test.bundle=true -# should be JPRT_TESTNATIVE_PATH -ifdef TEST_IMAGE_DIR - TESTNATIVE_DIR = $(TEST_IMAGE_DIR) -else ifdef JPRT_TESTNATIVE_PATH - TESTNATIVE_DIR = $(JPRT_TESTNATIVE_PATH) -endif -ifdef TESTNATIVE_DIR - JTREG_NATIVE_PATH = -nativepath:$(shell $(GETMIXEDPATH) "$(TESTNATIVE_DIR)/nashorn/jtreg/native") -endif - # jtreg failure handler config ifeq ($(FAILURE_HANDLER_DIR), ) ifneq ($(TESTNATIVE_DIR), ) From af4dcf2bfed245c8de5b65187da17bd234edd5b3 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Wed, 29 Jun 2016 20:00:55 +0200 Subject: [PATCH 094/125] 8160571: Bootcycle builds still broken with server jvm on Windows 32bit Reviewed-by: tbell --- common/autoconf/boot-jdk.m4 | 2 +- common/autoconf/bootcycle-spec.gmk.in | 2 +- common/autoconf/generated-configure.sh | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/common/autoconf/boot-jdk.m4 b/common/autoconf/boot-jdk.m4 index 1aded9e4486..30dcf844a88 100644 --- a/common/autoconf/boot-jdk.m4 +++ b/common/autoconf/boot-jdk.m4 @@ -362,7 +362,7 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], BOOTCYCLE_JVM_ARGS_BIG=-Xms64M # Maximum amount of heap memory and stack size. - JVM_HEAP_LIMIT_32="1100" + JVM_HEAP_LIMIT_32="1024" # Running a 64 bit JVM allows for and requires a bigger heap JVM_HEAP_LIMIT_64="1600" STACK_SIZE_32=768 diff --git a/common/autoconf/bootcycle-spec.gmk.in b/common/autoconf/bootcycle-spec.gmk.in index aa722761939..3c9c1dbe23b 100644 --- a/common/autoconf/bootcycle-spec.gmk.in +++ b/common/autoconf/bootcycle-spec.gmk.in @@ -64,7 +64,7 @@ SJAVAC_SERVER_JAVA_CMD:=$(JAVA_CMD) # When building a 32bit target, make sure the sjavac server flags are compatible # with a 32bit JVM. ifeq ($(OPENJDK_TARGET_CPU_BITS), 32) - SJAVAC_SERVER_JAVA_FLAGS:= -Xms256M -Xmx1500M + SJAVAC_SERVER_JAVA_FLAGS := @BOOTCYCLE_JVM_ARGS_BIG@ endif # The bootcycle JVM arguments may differ from the original boot jdk. JAVA_FLAGS_BIG := @BOOTCYCLE_JVM_ARGS_BIG@ diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 049b8936829..97f0fa94202 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -5095,7 +5095,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1467116399 +DATE_WHEN_GENERATED=1467223237 ############################################################################### # @@ -65122,7 +65122,7 @@ $as_echo_n "checking flags for boot jdk java command for big workloads... " >&6; BOOTCYCLE_JVM_ARGS_BIG=-Xms64M # Maximum amount of heap memory and stack size. - JVM_HEAP_LIMIT_32="1100" + JVM_HEAP_LIMIT_32="1024" # Running a 64 bit JVM allows for and requires a bigger heap JVM_HEAP_LIMIT_64="1600" STACK_SIZE_32=768 From 052984a47c587cd75c0a8700a86a183f80f1f035 Mon Sep 17 00:00:00 2001 From: Tim Du Date: Wed, 29 Jun 2016 23:29:07 -0700 Subject: [PATCH 095/125] 8160415: Mark sun/security/tools/keytool/standard.sh as intermittently failing Reviewed-by: weijun --- jdk/test/sun/security/tools/keytool/standard.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/test/sun/security/tools/keytool/standard.sh b/jdk/test/sun/security/tools/keytool/standard.sh index 8106ee44dcb..2fb801ebd83 100644 --- a/jdk/test/sun/security/tools/keytool/standard.sh +++ b/jdk/test/sun/security/tools/keytool/standard.sh @@ -25,6 +25,7 @@ # @summary (almost) all keytool behaviors # @author Weijun Wang # @run shell/timeout=600 standard.sh +# @key intermittent # # This test is always excecuted. # From ec5c0f3089325841e53d074b34aff593734cf465 Mon Sep 17 00:00:00 2001 From: Jamil Nimeh Date: Thu, 30 Jun 2016 00:09:06 -0700 Subject: [PATCH 096/125] 8143302: javax/net/ssl/Stapling/SSLSocketWithStapling.java fails intermittently: Server died Fixes a file descriptor leak in the test and a thread exhaustion issue in the StatusResponseManager in JSSE. Reviewed-by: xuelei --- .../security/ssl/StatusResponseManager.java | 5 +-- .../ssl/Stapling/SSLSocketWithStapling.java | 34 ++++++++++--------- 2 files changed, 21 insertions(+), 18 deletions(-) diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/StatusResponseManager.java b/jdk/src/java.base/share/classes/sun/security/ssl/StatusResponseManager.java index 0cc7cec686e..ee312952c44 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/StatusResponseManager.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/StatusResponseManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -97,10 +97,11 @@ final class StatusResponseManager { t.setDaemon(true); return t; } - }); + }, new ThreadPoolExecutor.DiscardPolicy()); threadMgr.setExecuteExistingDelayedTasksAfterShutdownPolicy(false); threadMgr.setContinueExistingPeriodicTasksAfterShutdownPolicy(false); threadMgr.setKeepAliveTime(5000, TimeUnit.MILLISECONDS); + threadMgr.allowCoreThreadTimeOut(true); responseCache = Cache.newSoftMemoryCache(cacheCapacity, cacheLifetime); } diff --git a/jdk/test/javax/net/ssl/Stapling/SSLSocketWithStapling.java b/jdk/test/javax/net/ssl/Stapling/SSLSocketWithStapling.java index 1f65e09d087..f1e5f1da945 100644 --- a/jdk/test/javax/net/ssl/Stapling/SSLSocketWithStapling.java +++ b/jdk/test/javax/net/ssl/Stapling/SSLSocketWithStapling.java @@ -510,25 +510,27 @@ public class SSLSocketWithStapling { sslc.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null); SSLServerSocketFactory sslssf = sslc.getServerSocketFactory(); - SSLServerSocket sslServerSocket = - (SSLServerSocket) sslssf.createServerSocket(serverPort); - serverPort = sslServerSocket.getLocalPort(); + try (SSLServerSocket sslServerSocket = + (SSLServerSocket) sslssf.createServerSocket(serverPort)) { - /* - * Signal Client, we're ready for his connect. - */ - serverReady = true; + serverPort = sslServerSocket.getLocalPort(); - try (SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept(); - InputStream sslIS = sslSocket.getInputStream(); - OutputStream sslOS = sslSocket.getOutputStream()) { - int numberIn = sslIS.read(); - int numberSent = 85; - log("Server received number: " + numberIn); - sslOS.write(numberSent); - sslOS.flush(); - log("Server sent number: " + numberSent); + /* + * Signal Client, we're ready for his connect. + */ + serverReady = true; + + try (SSLSocket sslSocket = (SSLSocket) sslServerSocket.accept(); + InputStream sslIS = sslSocket.getInputStream(); + OutputStream sslOS = sslSocket.getOutputStream()) { + int numberIn = sslIS.read(); + int numberSent = 85; + log("Server received number: " + numberIn); + sslOS.write(numberSent); + sslOS.flush(); + log("Server sent number: " + numberSent); + } } } From d755ba941f39a6333e2082968b2de3c8df35f9ef Mon Sep 17 00:00:00 2001 From: Christoph Langer Date: Thu, 30 Jun 2016 09:30:09 +0200 Subject: [PATCH 097/125] 8158023: SocketExceptions contain too little information sometimes Reviewed-by: rriggs, msheppar, chegar --- jdk/make/mapfiles/libjava/mapfile-vers | 1 + .../java.base/share/native/libjava/jni_util.c | 69 ++++++++- .../java.base/share/native/libjava/jni_util.h | 15 +- .../unix/native/libnet/NetworkInterface.c | 136 +++++++++--------- .../native/libnet/PlainDatagramSocketImpl.c | 91 ++++++------ .../unix/native/libnet/PlainSocketImpl.c | 54 +++---- .../unix/native/libnet/SocketInputStream.c | 10 +- .../unix/native/libnet/SocketOutputStream.c | 6 +- .../libnet/TwoStacksPlainDatagramSocketImpl.c | 34 ++--- .../native/libnet/TwoStacksPlainSocketImpl.c | 6 +- 10 files changed, 250 insertions(+), 172 deletions(-) diff --git a/jdk/make/mapfiles/libjava/mapfile-vers b/jdk/make/mapfiles/libjava/mapfile-vers index 8bd1118c1ff..c34ba2f709d 100644 --- a/jdk/make/mapfiles/libjava/mapfile-vers +++ b/jdk/make/mapfiles/libjava/mapfile-vers @@ -56,6 +56,7 @@ SUNWprivate_1.1 { JNU_ThrowArrayIndexOutOfBoundsException; JNU_ThrowByName; JNU_ThrowByNameWithLastError; + JNU_ThrowByNameWithMessageAndLastError; JNU_ThrowClassNotFoundException; JNU_ThrowIllegalAccessError; JNU_ThrowIllegalAccessException; diff --git a/jdk/src/java.base/share/native/libjava/jni_util.c b/jdk/src/java.base/share/native/libjava/jni_util.c index 89f6edb7c03..3ea11b0bbc6 100644 --- a/jdk/src/java.base/share/native/libjava/jni_util.c +++ b/jdk/src/java.base/share/native/libjava/jni_util.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -147,9 +147,9 @@ JNU_ThrowInstantiationException(JNIEnv *env, const char *msg) JNU_ThrowByName(env, "java/lang/InstantiationException", msg); } - -/* Throw an exception by name, using the string returned by - * JVM_LastErrorString for the detail string. If the last-error +/* + * Throw an exception by name, using the string returned by + * getLastErrorString for the detail string. If the last-error * string is NULL, use the given default detail string. */ JNIEXPORT void JNICALL @@ -174,9 +174,64 @@ JNU_ThrowByNameWithLastError(JNIEnv *env, const char *name, } } -/* Throw an IOException, using the last-error string for the detail - * string. If the last-error string is NULL, use the given default - * detail string. +/* + * Throw an exception by name, using a given message and the string + * returned by getLastErrorString to construct the detail string. + */ +JNIEXPORT void JNICALL +JNU_ThrowByNameWithMessageAndLastError + (JNIEnv *env, const char *name, const char *message) +{ + char buf[256]; + size_t n = getLastErrorString(buf, sizeof(buf)); + size_t messagelen = message == NULL ? 0 : strlen(message); + + if (n > 0) { + jstring s = JNU_NewStringPlatform(env, buf); + if (s != NULL) { + jobject x = NULL; + if (messagelen) { + jstring s2 = NULL; + size_t messageextlen = messagelen + 4; + char *str1 = (char *)malloc((messageextlen) * sizeof(char)); + if (str1 == 0) { + JNU_ThrowOutOfMemoryError(env, 0); + return; + } + jio_snprintf(str1, messageextlen, " (%s)", message); + s2 = (*env)->NewStringUTF(env, str1); + free(str1); + if (s2 != NULL) { + jstring s3 = JNU_CallMethodByName( + env, NULL, s, "concat", + "(Ljava/lang/String;)Ljava/lang/String;", + s2).l; + (*env)->DeleteLocalRef(env, s2); + if (s3 != NULL) { + (*env)->DeleteLocalRef(env, s); + s = s3; + } + } + } + x = JNU_NewObjectByName(env, name, "(Ljava/lang/String;)V", s); + if (x != NULL) { + (*env)->Throw(env, x); + } + } + } + + if (!(*env)->ExceptionOccurred(env)) { + if (messagelen) { + JNU_ThrowByName(env, name, message); + } else { + JNU_ThrowByName(env, name, "no further information"); + } + } +} + +/* + * Convenience method. + * Call JNU_ThrowByNameWithLastError for java.io.IOException. */ JNIEXPORT void JNICALL JNU_ThrowIOExceptionWithLastError(JNIEnv *env, const char *defaultDetail) diff --git a/jdk/src/java.base/share/native/libjava/jni_util.h b/jdk/src/java.base/share/native/libjava/jni_util.h index 96796571dc7..960a225efbb 100644 --- a/jdk/src/java.base/share/native/libjava/jni_util.h +++ b/jdk/src/java.base/share/native/libjava/jni_util.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -98,15 +98,22 @@ JNIEXPORT void JNICALL JNU_ThrowInstantiationException(JNIEnv *env, const char *msg); /* Throw an exception by name, using the string returned by - * JVM_LastErrorString for the detail string. If the last-error + * getLastErrorString for the detail string. If the last-error * string is NULL, use the given default detail string. */ JNIEXPORT void JNICALL JNU_ThrowByNameWithLastError(JNIEnv *env, const char *name, - const char *defaultMessage); + const char *defaultDetail); + +/* Throw an exception by name, using a given message and the string + * returned by getLastErrorString to construct the detail string. + */ +JNIEXPORT void JNICALL +JNU_ThrowByNameWithMessageAndLastError + (JNIEnv *env, const char *name, const char *message); /* Throw an IOException, using the last-error string for the detail - * string. If the last-error string is NULL, use the given default + * string. If the last-error string is NULL, use the given default * detail string. */ JNIEXPORT void JNICALL diff --git a/jdk/src/java.base/unix/native/libnet/NetworkInterface.c b/jdk/src/java.base/unix/native/libnet/NetworkInterface.c index 863aa591059..e93824f8d04 100644 --- a/jdk/src/java.base/unix/native/libnet/NetworkInterface.c +++ b/jdk/src/java.base/unix/native/libnet/NetworkInterface.c @@ -621,8 +621,8 @@ static int getFlags0(JNIEnv *env, jstring name) { (*env)->ReleaseStringUTFChars(env, name, name_utf); if (ret < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFFLAGS failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "getFlags() failed"); return -1; } @@ -1061,8 +1061,8 @@ static int openSocket(JNIEnv *env, int proto) { // If EPROTONOSUPPORT is returned it means we don't have // support for this proto so don't throw an exception. if (errno != EPROTONOSUPPORT) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Socket creation failed"); } return -1; } @@ -1087,13 +1087,13 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if (errno == EPROTONOSUPPORT) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV6 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); return -1; } } else { // errno is not NOSUPPORT - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV4 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV4 Socket creation failed"); return -1; } } @@ -1122,15 +1122,15 @@ static netif *enumIPv4Interfaces(JNIEnv *env, int sock, netif *ifs) { // SIOCGIFCOUNT doesn't work ifc.ifc_buf = NULL; if (ioctl(sock, SIOCGIFCONF, (char *)&ifc) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFCONF) failed"); return ifs; } #elif defined(_AIX) ifc.ifc_buf = NULL; if (ioctl(sock, SIOCGSIZIFCONF, &(ifc.ifc_len)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGSIZIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGSIZIFCONF) failed"); return ifs; } #endif /* __linux__ */ @@ -1142,8 +1142,8 @@ static netif *enumIPv4Interfaces(JNIEnv *env, int sock, netif *ifs) { siocgifconfRequest = CSIOCGIFCONF; #endif if (ioctl(sock, siocgifconfRequest, (char *)&ifc) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFCONF) failed"); free(buf); return ifs; } @@ -1268,8 +1268,8 @@ static netif *enumIPv6Interfaces(JNIEnv *env, int sock, netif *ifs) { ifc.ifc_buf = NULL; if (ioctl(sock, SIOCGSIZIFCONF, &(ifc.ifc_len)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGSIZIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGSIZIFCONF) failed"); return ifs; } bufsize = ifc.ifc_len; @@ -1282,8 +1282,8 @@ static netif *enumIPv6Interfaces(JNIEnv *env, int sock, netif *ifs) { ifc.ifc_len = bufsize; ifc.ifc_buf = buf; if (ioctl(sock, SIOCGIFCONF, (char *)&ifc) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl CSIOCGIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFCONF) failed"); free(buf); return ifs; } @@ -1368,16 +1368,16 @@ static struct sockaddr *getBroadcast // Let's make sure the interface does have a broadcast address. if (ioctl(sock, SIOCGIFFLAGS, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFFLAGS failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFFLAGS) failed"); return ret; } if (if2.ifr_flags & IFF_BROADCAST) { // It does, let's retrieve it if (ioctl(sock, SIOCGIFBRDADDR, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFBRDADDR failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFBRDADDR) failed"); return ret; } @@ -1400,8 +1400,8 @@ static short getSubnet(JNIEnv *env, int sock, const char *ifname) { strncpy(if2.ifr_name, ifname, sizeof(if2.ifr_name) - 1); if (ioctl(sock, SIOCGIFNETMASK, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFNETMASK failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFNETMASK) failed"); return -1; } @@ -1463,8 +1463,8 @@ static int getMacAddress memset((char *)&ifr, 0, sizeof(ifr)); strncpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name) - 1); if (ioctl(sock, SIOCGIFHWADDR, &ifr) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFHWADDR failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFHWADDR) failed"); return -1; } @@ -1493,8 +1493,8 @@ static int getMTU(JNIEnv *env, int sock, const char *ifname) { } if (ioctl(sock, SIOCGIFMTU, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFMTU failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFMTU) failed"); return -1; } @@ -1535,15 +1535,15 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if (errno == EPROTONOSUPPORT) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV6 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); return -1; } alreadyV6=1; } else { // errno is not NOSUPPORT - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV4 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV4 Socket creation failed"); return -1; } } @@ -1562,8 +1562,8 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) { if (ioctl(sock, SIOCGLIFNETMASK, (char *)&if2) < 0) { close(sock); if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV6 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); return -1; } } @@ -1607,8 +1607,8 @@ static netif *enumIPvXInterfaces(JNIEnv *env, int sock, netif *ifs, int family) numifs.lifn_family = family; numifs.lifn_flags = 0; if (ioctl(sock, SIOCGLIFNUM, (char *)&numifs) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFNUM failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFNUM) failed"); return ifs; } @@ -1621,8 +1621,8 @@ static netif *enumIPvXInterfaces(JNIEnv *env, int sock, netif *ifs, int family) ifc.lifc_len = bufsize; ifc.lifc_buf = buf; if (ioctl(sock, SIOCGLIFCONF, (char *)&ifc) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFCONF failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFCONF) failed"); free(buf); return ifs; } @@ -1689,16 +1689,16 @@ static struct sockaddr *getBroadcast // Let's make sure the interface does have a broadcast address if (ioctl(sock, SIOCGLIFFLAGS, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFFLAGS failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFFLAGS) failed"); return ret; } if (if2.lifr_flags & IFF_BROADCAST) { // It does, let's retrieve it if (ioctl(sock, SIOCGLIFBRDADDR, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFBRDADDR failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFBRDADDR) failed"); return ret; } @@ -1721,8 +1721,8 @@ static short getSubnet(JNIEnv *env, int sock, const char *ifname) { strncpy(if2.lifr_name, ifname, sizeof(if2.lifr_name) - 1); if (ioctl(sock, SIOCGLIFNETMASK, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFNETMASK failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFNETMASK) failed"); return -1; } @@ -1764,8 +1764,8 @@ static int getMacFromDevice msg.len = DL_PHYS_ADDR_REQ_SIZE; if (putmsg(fd, &msg, NULL, 0) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "putmsg failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "putmsg() failed"); return -1; } @@ -1775,8 +1775,8 @@ static int getMacFromDevice msg.len = 0; msg.maxlen = sizeof (buf); if (getmsg(fd, &msg, NULL, &flags) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "getmsg failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "getmsg() failed"); return -1; } @@ -1860,8 +1860,8 @@ static int getMTU(JNIEnv *env, int sock, const char *ifname) { strncpy(if2.lifr_name, ifname, sizeof(if2.lifr_name) - 1); if (ioctl(sock, SIOCGLIFMTU, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGLIFMTU failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGLIFMTU) failed"); return -1; } @@ -1900,13 +1900,13 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if (errno == EPROTONOSUPPORT) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV6 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); return -1; } } else { // errno is not NOSUPPORT - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "IPV4 Socket creation failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "IPV4 Socket creation failed"); return -1; } } @@ -1927,8 +1927,8 @@ static netif *enumIPv4Interfaces(JNIEnv *env, int sock, netif *ifs) { struct ifaddrs *ifa, *origifa; if (getifaddrs(&origifa) != 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "getifaddrs() function failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "getifaddrs() failed"); return ifs; } @@ -1997,8 +1997,8 @@ static netif *enumIPv6Interfaces(JNIEnv *env, int sock, netif *ifs) { struct in6_ifreq ifr6; if (getifaddrs(&origifa) != 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "getifaddrs() function failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "getifaddrs() failed"); return ifs; } @@ -2014,8 +2014,8 @@ static netif *enumIPv6Interfaces(JNIEnv *env, int sock, netif *ifs) { MIN(sizeof(ifr6.ifr_addr), ifa->ifa_addr->sa_len)); if (ioctl(sock, SIOCGIFNETMASK_IN6, (caddr_t)&ifr6) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFNETMASK_IN6 failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFNETMASK_IN6) failed"); freeifaddrs(origifa); freeif(ifs); return NULL; @@ -2075,16 +2075,16 @@ static struct sockaddr *getBroadcast // Make sure the interface does have a broadcast address if (ioctl(sock, SIOCGIFFLAGS, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFFLAGS failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFFLAGS) failed"); return ret; } if (if2.ifr_flags & IFF_BROADCAST) { // It does, let's retrieve it if (ioctl(sock, SIOCGIFBRDADDR, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFBRDADDR failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFBRDADDR) failed"); return ret; } @@ -2107,8 +2107,8 @@ static short getSubnet(JNIEnv *env, int sock, const char *ifname) { strncpy(if2.ifr_name, ifname, sizeof(if2.ifr_name) - 1); if (ioctl(sock, SIOCGIFNETMASK, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFNETMASK failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFNETMASK) failed"); return -1; } @@ -2156,8 +2156,8 @@ static int getMTU(JNIEnv *env, int sock, const char *ifname) { strncpy(if2.ifr_name, ifname, sizeof(if2.ifr_name) - 1); if (ioctl(sock, SIOCGIFMTU, (char *)&if2) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl SIOCGIFMTU failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl(SIOCGIFMTU) failed"); return -1; } diff --git a/jdk/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c b/jdk/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c index 034040baf83..f141ad234c4 100644 --- a/jdk/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c +++ b/jdk/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c @@ -221,8 +221,8 @@ Java_java_net_PlainDatagramSocketImpl_bind0(JNIEnv *env, jobject this, NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "BindException", "Bind failed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Bind failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Bind failed"); } return; } @@ -233,8 +233,8 @@ Java_java_net_PlainDatagramSocketImpl_bind0(JNIEnv *env, jobject this, * that the system chose for us and store it in the Socket object. */ if (getsockname(fd, (struct sockaddr *)&him, &slen) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return; } @@ -469,7 +469,7 @@ Java_java_net_PlainDatagramSocketImpl_send(JNIEnv *env, jobject this, JNU_ThrowByName(env, JNU_JAVANETPKG "PortUnreachableException", "ICMP Port Unreachable"); } else { - NET_ThrowByNameWithLastError(env, "java/io/IOException", "sendto failed"); + JNU_ThrowIOExceptionWithLastError(env, "sendto failed"); } } @@ -520,7 +520,8 @@ Java_java_net_PlainDatagramSocketImpl_peek(JNIEnv *env, jobject this, } else if (errno == ENOMEM) { JNU_ThrowOutOfMemoryError(env, "NET_Timeout native heap allocation failed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Peek failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Peek failed"); } return ret; } @@ -544,7 +545,8 @@ Java_java_net_PlainDatagramSocketImpl_peek(JNIEnv *env, jobject this, if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Peek failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Peek failed"); } } return 0; @@ -616,7 +618,8 @@ Java_java_net_PlainDatagramSocketImpl_peekData(JNIEnv *env, jobject this, } else if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Receive failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Receive failed"); #else } else { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); @@ -681,7 +684,8 @@ Java_java_net_PlainDatagramSocketImpl_peekData(JNIEnv *env, jobject this, if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Receive failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Receive failed"); } } } else { @@ -827,7 +831,8 @@ Java_java_net_PlainDatagramSocketImpl_receive0(JNIEnv *env, jobject this, } else if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Receive failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Receive failed"); #else } else { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); @@ -859,7 +864,8 @@ Java_java_net_PlainDatagramSocketImpl_receive0(JNIEnv *env, jobject this, if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Receive failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Receive failed"); } } } else { @@ -932,8 +938,8 @@ Java_java_net_PlainDatagramSocketImpl_datagramSocketCreate(JNIEnv *env, } if ((fd = socket(domain, SOCK_DGRAM, 0)) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error creating socket"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error creating socket"); return; } @@ -1080,8 +1086,8 @@ static void mcast_set_if_by_if_v4(JNIEnv *env, jobject this, int fd, jobject val if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (const char*)&in, sizeof(in)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } } @@ -1109,8 +1115,8 @@ static void mcast_set_if_by_if_v6(JNIEnv *env, jobject this, int fd, jobject val "IPV6_MULTICAST_IF failed (interface has IPv4 " "address only?)"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } return; } @@ -1129,8 +1135,8 @@ static void mcast_set_if_by_addr_v4(JNIEnv *env, jobject this, int fd, jobject v if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (const char*)&in, sizeof(in)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } } @@ -1256,8 +1262,10 @@ static void mcast_set_loop_v4(JNIEnv *env, jobject this, int fd, jobject value) on = (*env)->GetBooleanField(env, value, fid); loopback = (!on ? 1 : 0); - if (NET_SetSockOpt(fd, IPPROTO_IP, IP_MULTICAST_LOOP, (const void *)&loopback, sizeof(char)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); + if (NET_SetSockOpt(fd, IPPROTO_IP, IP_MULTICAST_LOOP, + (const void *)&loopback, sizeof(char)) < 0) { + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); return; } } @@ -1280,8 +1288,10 @@ static void mcast_set_loop_v6(JNIEnv *env, jobject this, int fd, jobject value) on = (*env)->GetBooleanField(env, value, fid); loopback = (!on ? 1 : 0); - if (NET_SetSockOpt(fd, IPPROTO_IPV6, IPV6_MULTICAST_LOOP, (const void *)&loopback, sizeof(int)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); + if (NET_SetSockOpt(fd, IPPROTO_IPV6, IPV6_MULTICAST_LOOP, + (const void *)&loopback, sizeof(int)) < 0) { + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); return; } @@ -1420,7 +1430,8 @@ Java_java_net_PlainDatagramSocketImpl_socketSetOption0(JNIEnv *env, } if (NET_SetSockOpt(fd, level, optname, (const void *)&optval, optlen) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); return; } } @@ -1483,8 +1494,8 @@ jobject getMulticastInterface(JNIEnv *env, jobject this, int fd, jint opt) { if (getsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (char *)inP, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return NULL; } @@ -1581,8 +1592,8 @@ jobject getMulticastInterface(JNIEnv *env, jobject this, int fd, jint opt) { if (getsockopt(fd, IPPROTO_IPV6, IPV6_MULTICAST_IF, (char*)&index, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return NULL; } @@ -1726,8 +1737,8 @@ Java_java_net_PlainDatagramSocketImpl_socketGetOption(JNIEnv *env, jobject this, len = SOCKADDR_LEN; if (getsockname(fd, (struct sockaddr *)&him, &len) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return NULL; } iaObj = NET_SockaddrToInetAddress(env, (struct sockaddr *)&him, &port); @@ -1752,8 +1763,8 @@ Java_java_net_PlainDatagramSocketImpl_socketGetOption(JNIEnv *env, jobject this, } if (NET_GetSockOpt(fd, level, optname, (void *)&optval, &optlen) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return NULL; } @@ -1805,8 +1816,8 @@ static void setTTL(JNIEnv *env, int fd, jint ttl) { char ittl = (char)ttl; if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_TTL, (char*)&ittl, sizeof(ittl)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } } @@ -1818,8 +1829,8 @@ static void setHopLimit(JNIEnv *env, int fd, jint ttl) { int ittl = (int)ttl; if (setsockopt(fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, (char*)&ittl, sizeof(ittl)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } } #endif @@ -1901,8 +1912,8 @@ Java_java_net_PlainDatagramSocketImpl_getTimeToLive(JNIEnv *env, jobject this) { if (getsockopt(fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, (char*)&ttl, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return -1; } return (jint)ttl; @@ -1913,8 +1924,8 @@ Java_java_net_PlainDatagramSocketImpl_getTimeToLive(JNIEnv *env, jobject this) { socklen_t len = sizeof(ttl); if (getsockopt(fd, IPPROTO_IP, IP_MULTICAST_TTL, (char*)&ttl, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return -1; } return (jint)ttl; diff --git a/jdk/src/java.base/unix/native/libnet/PlainSocketImpl.c b/jdk/src/java.base/unix/native/libnet/PlainSocketImpl.c index 01d763a2c2d..ba8e483c101 100644 --- a/jdk/src/java.base/unix/native/libnet/PlainSocketImpl.c +++ b/jdk/src/java.base/unix/native/libnet/PlainSocketImpl.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -476,7 +476,8 @@ Java_java_net_PlainSocketImpl_socketConnect(JNIEnv *env, jobject this, JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "connect failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "connect failed"); } return; } @@ -498,8 +499,8 @@ Java_java_net_PlainSocketImpl_socketConnect(JNIEnv *env, jobject this, */ socklen_t slen = SOCKADDR_LEN; if (getsockname(fd, (struct sockaddr *)&him, &slen) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); } else { localport = NET_GetPortFromSockaddr((struct sockaddr *)&him); (*env)->SetIntField(env, this, psi_localportID, localport); @@ -536,8 +537,9 @@ Java_java_net_PlainSocketImpl_socketBind(JNIEnv *env, jobject this, } /* bind */ - if (NET_InetAddressToSockaddr(env, iaObj, localport, (struct sockaddr *)&him, &len, JNI_TRUE) != 0) { - return; + if (NET_InetAddressToSockaddr(env, iaObj, localport, (struct sockaddr *)&him, + &len, JNI_TRUE) != 0) { + return; } setDefaultScopeID(env, (struct sockaddr *)&him); @@ -547,8 +549,8 @@ Java_java_net_PlainSocketImpl_socketBind(JNIEnv *env, jobject this, NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "BindException", "Bind failed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Bind failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Bind failed"); } return; } @@ -563,8 +565,8 @@ Java_java_net_PlainSocketImpl_socketBind(JNIEnv *env, jobject this, * that the system chose for us and store it in the Socket object. */ if (getsockname(fd, (struct sockaddr *)&him, &slen) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return; } localport = NET_GetPortFromSockaddr((struct sockaddr *)&him); @@ -580,8 +582,8 @@ Java_java_net_PlainSocketImpl_socketBind(JNIEnv *env, jobject this, * Signature: (I)V */ JNIEXPORT void JNICALL -Java_java_net_PlainSocketImpl_socketListen (JNIEnv *env, jobject this, - jint count) +Java_java_net_PlainSocketImpl_socketListen(JNIEnv *env, jobject this, + jint count) { /* this FileDescriptor fd field */ jobject fdObj = (*env)->GetObjectField(env, this, psi_fdID); @@ -604,8 +606,8 @@ Java_java_net_PlainSocketImpl_socketListen (JNIEnv *env, jobject this, count -= 1; if (listen(fd, count) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Listen failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Listen failed"); } } @@ -684,7 +686,8 @@ Java_java_net_PlainSocketImpl_socketAccept(JNIEnv *env, jobject this, } else if (errno == ENOMEM) { JNU_ThrowOutOfMemoryError(env, "NET_Timeout native heap allocation failed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Accept failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Accept failed"); } return; } @@ -727,7 +730,8 @@ Java_java_net_PlainSocketImpl_socketAccept(JNIEnv *env, jobject this, if (errno == EBADF) { JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", "Socket closed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", "Accept failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Accept failed"); } } return; @@ -781,8 +785,8 @@ Java_java_net_PlainSocketImpl_socketAvailable(JNIEnv *env, jobject this) { if (errno == ECONNRESET) { JNU_ThrowByName(env, "sun/net/ConnectionResetException", ""); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "ioctl FIONREAD failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "ioctl FIONREAD failed"); } } return ret; @@ -936,8 +940,8 @@ Java_java_net_PlainSocketImpl_socketSetOption0(JNIEnv *env, jobject this, return; } #endif /* __solaris__ */ - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } } @@ -981,8 +985,8 @@ Java_java_net_PlainSocketImpl_socketGetOption(JNIEnv *env, jobject this, len = SOCKADDR_LEN; if (getsockname(fd, (struct sockaddr *)&him, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return -1; } iaObj = NET_SockaddrToInetAddress(env, (struct sockaddr *)&him, &port); @@ -1014,8 +1018,8 @@ Java_java_net_PlainSocketImpl_socketGetOption(JNIEnv *env, jobject this, } if (NET_GetSockOpt(fd, level, optname, (void *)&optval, &optlen) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return -1; } @@ -1063,6 +1067,6 @@ Java_java_net_PlainSocketImpl_socketSendUrgentData(JNIEnv *env, jobject this, } n = NET_Send(fd, (char *)&d, 1, MSG_OOB); if (n == -1) { - NET_ThrowByNameWithLastError(env, "java/io/IOException", "Write failed"); + JNU_ThrowIOExceptionWithLastError(env, "Write failed"); } } diff --git a/jdk/src/java.base/unix/native/libnet/SocketInputStream.c b/jdk/src/java.base/unix/native/libnet/SocketInputStream.c index 9857d18573b..08d8508b154 100644 --- a/jdk/src/java.base/unix/native/libnet/SocketInputStream.c +++ b/jdk/src/java.base/unix/native/libnet/SocketInputStream.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -111,8 +111,8 @@ Java_java_net_SocketInputStream_socketRead0(JNIEnv *env, jobject this, } else if (errno == ENOMEM) { JNU_ThrowOutOfMemoryError(env, "NET_Timeout native heap allocation failed"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "select/poll failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "select/poll failed"); } } if (bufP != BUF) { @@ -145,8 +145,8 @@ Java_java_net_SocketInputStream_socketRead0(JNIEnv *env, jobject this, break; default: - NET_ThrowByNameWithLastError(env, - JNU_JAVANETPKG "SocketException", "Read failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Read failed"); } } } else { diff --git a/jdk/src/java.base/unix/native/libnet/SocketOutputStream.c b/jdk/src/java.base/unix/native/libnet/SocketOutputStream.c index 5d40bd83df3..f5a685a741c 100644 --- a/jdk/src/java.base/unix/native/libnet/SocketOutputStream.c +++ b/jdk/src/java.base/unix/native/libnet/SocketOutputStream.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2008, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -114,8 +114,8 @@ Java_java_net_SocketOutputStream_socketWrite0(JNIEnv *env, jobject this, JNU_ThrowByName(env, "sun/net/ConnectionResetException", "Connection reset"); } else { - NET_ThrowByNameWithLastError(env, "java/net/SocketException", - "Write failed"); + JNU_ThrowByNameWithMessageAndLastError + (env, "java/net/SocketException", "Write failed"); } if (bufP != BUF) { free(bufP); diff --git a/jdk/src/java.base/windows/native/libnet/TwoStacksPlainDatagramSocketImpl.c b/jdk/src/java.base/windows/native/libnet/TwoStacksPlainDatagramSocketImpl.c index 3db3d7b2fc2..b37adf7e1d4 100644 --- a/jdk/src/java.base/windows/native/libnet/TwoStacksPlainDatagramSocketImpl.c +++ b/jdk/src/java.base/windows/native/libnet/TwoStacksPlainDatagramSocketImpl.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1713,8 +1713,8 @@ static void setMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, in.s_addr = htonl(getInetAddress_addr(env, value)); if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (const char*)&in, sizeof(in)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } return; } @@ -1741,7 +1741,7 @@ static void setMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, } index = (*env)->GetIntField(env, value, ni_indexID); - if ( isAdapterIpv6Enabled(env, index) != 0 ) { + if (isAdapterIpv6Enabled(env, index) != 0) { if (setsockopt(fd1, IPPROTO_IPV6, IPV6_MULTICAST_IF, (const char*)&index, sizeof(index)) < 0) { if (errno == EINVAL && index > 0) { @@ -1749,8 +1749,8 @@ static void setMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, "IPV6_MULTICAST_IF failed (interface has IPv4 " "address only?)"); } else { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } return; } @@ -1758,13 +1758,13 @@ static void setMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, /* If there are any IPv4 addresses on this interface then * repeat the operation on the IPv4 fd */ - if (getInet4AddrFromIf (env, value, &in) < 0) { + if (getInet4AddrFromIf(env, value, &in) < 0) { return; } if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (const char*)&in, sizeof(in)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } return; } else { @@ -1781,8 +1781,8 @@ static void setMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, if (setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (const char*)&in, sizeof(in)) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error setting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error setting socket option"); } return; } @@ -1932,8 +1932,8 @@ static jobject getIPv4NetworkInterface (JNIEnv *env, jobject this, int fd, jint int len = sizeof(struct in_addr); if (getsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, (char *)inP, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return NULL; } @@ -2056,8 +2056,8 @@ jobject getMulticastInterface(JNIEnv *env, jobject this, int fd, int fd1, jint o { if (getsockopt(fd1, IPPROTO_IPV6, IPV6_MULTICAST_IF, (char*)&index, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket option"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket option"); return NULL; } } @@ -2288,8 +2288,8 @@ Java_java_net_TwoStacksPlainDatagramSocketImpl_socketLocalAddress(JNIEnv *env, j } if (getsockname(fd, (struct sockaddr *)&him, &len) == -1) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return NULL; } iaObj = NET_SockaddrToInetAddress(env, (struct sockaddr *)&him, &port); diff --git a/jdk/src/java.base/windows/native/libnet/TwoStacksPlainSocketImpl.c b/jdk/src/java.base/windows/native/libnet/TwoStacksPlainSocketImpl.c index b4f9f140789..3d950d3d4ad 100644 --- a/jdk/src/java.base/windows/native/libnet/TwoStacksPlainSocketImpl.c +++ b/jdk/src/java.base/windows/native/libnet/TwoStacksPlainSocketImpl.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1054,8 +1054,8 @@ Java_java_net_TwoStacksPlainSocketImpl_socketGetOption(JNIEnv *env, jobject this } if (getsockname(fd, (struct sockaddr *)&him, &len) < 0) { - NET_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "Error getting socket name"); + JNU_ThrowByNameWithMessageAndLastError + (env, JNU_JAVANETPKG "SocketException", "Error getting socket name"); return -1; } iaObj = NET_SockaddrToInetAddress(env, (struct sockaddr *)&him, &port); From 657cb0f3b42262f031ec18054d329965daa84690 Mon Sep 17 00:00:00 2001 From: Yuka Kamiya Date: Thu, 30 Jun 2016 16:57:25 +0900 Subject: [PATCH 098/125] 7090039: Wrong link in comment of java.text.DateFormatSymbols Reviewed-by: okutsu --- .../java.base/share/classes/java/text/DateFormatSymbols.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java b/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java index 74eba85bd16..f94a94e252f 100644 --- a/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java +++ b/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java @@ -221,7 +221,7 @@ public class DateFormatSymbols implements Serializable, Cloneable { * * The zone ID is not localized; it's one of the valid IDs of * the {@link java.util.TimeZone TimeZone} class that are not - * custom IDs. + * custom IDs. * All other entries are localized names. * @see java.util.TimeZone * @serial From 07720b0e617e62c90f2390ab7e5f5568a39fcb8a Mon Sep 17 00:00:00 2001 From: Jamil Nimeh Date: Thu, 30 Jun 2016 07:14:56 -0700 Subject: [PATCH 099/125] 8030132: Cipher.init syntax error in javadoc @code tag 8160222: javax/crypto/Cipher.java has a typo Fixes typographical errors in javax/crypto/Cipher.java Reviewed-by: weijun --- .../share/classes/javax/crypto/Cipher.java | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/jdk/src/java.base/share/classes/javax/crypto/Cipher.java b/jdk/src/java.base/share/classes/javax/crypto/Cipher.java index 8b5fb7875af..497069cd7fc 100644 --- a/jdk/src/java.base/share/classes/javax/crypto/Cipher.java +++ b/jdk/src/java.base/share/classes/javax/crypto/Cipher.java @@ -93,7 +93,7 @@ import sun.security.jca.*; * provide authenticity assurances for both confidential data and * Additional Associated Data (AAD) that is not encrypted. (Please see * RFC 5116 for more - * information on AEAD and AEAD algorithms such as GCM/CCM.) Both + * information on AEAD and AAD algorithms such as GCM/CCM.) Both * confidential and AAD data can be used when calculating the * authentication tag (similar to a {@link Mac}). This tag is appended * to the ciphertext during encryption, and is verified on decryption. @@ -1186,7 +1186,7 @@ public class Cipher { * determined from the given key, or if the given key has a keysize that * exceeds the maximum allowable keysize (as determined from the * configured jurisdiction policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1239,7 +1239,7 @@ public class Cipher { * determined from the given key, or if the given key has a keysize that * exceeds the maximum allowable keysize (as determined from the * configured jurisdiction policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1325,7 +1325,7 @@ public class Cipher { * algorithm parameters imply a cryptographic strength that would exceed * the legal limits (as determined from the configured jurisdiction * policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1386,7 +1386,7 @@ public class Cipher { * algorithm parameters imply a cryptographic strength that would exceed * the legal limits (as determined from the configured jurisdiction * policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1468,7 +1468,7 @@ public class Cipher { * algorithm parameters imply a cryptographic strength that would exceed * the legal limits (as determined from the configured jurisdiction * policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1529,7 +1529,7 @@ public class Cipher { * algorithm parameters imply a cryptographic strength that would exceed * the legal limits (as determined from the configured jurisdiction * policy files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1616,7 +1616,7 @@ public class Cipher { * in the given certificate has a keysize that exceeds the maximum * allowable keysize (as determined by the configured jurisdiction policy * files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ @@ -1686,7 +1686,7 @@ public class Cipher { * in the given certificate has a keysize that exceeds the maximum * allowable keysize (as determined by the configured jurisdiction policy * files). - * @throws UnsupportedOperationException if (@code opmode} is + * @throws UnsupportedOperationException if {@code opmode} is * {@code WRAP_MODE} or {@code UNWRAP_MODE} but the mode is not implemented * by the underlying {@code CipherSpi}. */ From a0f8120f0a11a2f66c1fb0116501f83a7a2d1ec6 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Thu, 30 Jun 2016 22:24:01 +0530 Subject: [PATCH 100/125] 8160641: PostProcessingPlugin and ExecutableImage should not be part of plugin API Reviewed-by: jlaskey, mchung --- .../share/classes/jdk/tools/jlink/Jlink.java | 2 +- .../jlink/builder/DefaultImageBuilder.java | 2 +- .../jdk/tools/jlink/builder/ImageBuilder.java | 2 +- .../{plugin => internal}/ExecutableImage.java | 2 +- .../jlink/internal/ImageFileCreator.java | 1 - .../internal/ImagePluginConfiguration.java | 27 ++--------- .../jlink/internal/ImagePluginStack.java | 31 ++++-------- .../jdk/tools/jlink/internal/JlinkTask.java | 5 +- .../jlink/internal/PluginRepository.java | 23 ++------- .../PostProcessor.java} | 8 ++-- .../jdk/tools/jlink/internal/TaskHelper.java | 33 ++++--------- .../jdk/tools/jlink/internal/Utils.java | 47 ++----------------- .../plugins/DefaultCompressPlugin.java | 4 +- .../internal/plugins/ExcludeFilesPlugin.java | 4 +- .../jlink/internal/plugins/ExcludePlugin.java | 4 +- .../internal/plugins/ExcludeVMPlugin.java | 4 +- .../internal/plugins/FileCopierPlugin.java | 4 +- .../plugins/GenerateJLIClassesPlugin.java | 4 +- .../plugins/IncludeLocalesPlugin.java | 4 +- .../plugins/OrderResourcesPlugin.java | 4 +- .../internal/plugins/ReleaseInfoPlugin.java | 4 +- .../internal/plugins/StringSharingPlugin.java | 4 +- .../internal/plugins/StripDebugPlugin.java | 4 +- .../plugins/StripNativeCommandsPlugin.java | 4 +- .../plugins/SystemModuleDescriptorPlugin.java | 4 +- .../jlink/internal/plugins/ZipPlugin.java | 4 +- .../jlink/internal/plugins/asm/AsmPlugin.java | 4 +- .../jdk/tools/jlink/plugin/Plugin.java | 29 ++++++------ .../tools/jlink/plugin/TransformerPlugin.java | 44 ----------------- .../jdk.jlink/share/classes/module-info.java | 29 ++++++------ jdk/test/tools/jlink/DefaultProviderTest.java | 3 +- .../tools/jlink/ImageFileCreatorTest.java | 4 +- jdk/test/tools/jlink/IntegrationTest.java | 17 ++++--- jdk/test/tools/jlink/JLinkOptionsTest.java | 4 +- .../tools/jlink/JLinkPostProcessingTest.java | 14 ++++-- jdk/test/tools/jlink/JLinkTest.java | 3 +- .../tools/jlink/customplugin/module-info.java | 4 +- .../customplugin/plugin/CustomPlugin.java | 4 +- .../customplugin/plugin/HelloPlugin.java | 4 +- .../jlink/plugins/CompressorPluginTest.java | 4 +- .../jlink/plugins/ExcludeFilesPluginTest.java | 1 - .../jlink/plugins/ExcludeVMPluginTest.java | 3 +- .../tools/jlink/plugins/LastSorterTest.java | 3 +- .../plugins/OrderResourcesPluginTest.java | 6 +-- .../tools/jlink/plugins/PluginOrderTest.java | 3 +- .../jlink/plugins/PluginsNegativeTest.java | 3 +- .../tools/jlink/plugins/PrevisitorTest.java | 3 +- .../plugins/StringSharingPluginTest.java | 4 +- .../jlink/plugins/StripDebugPluginTest.java | 4 +- 49 files changed, 148 insertions(+), 288 deletions(-) rename jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/{plugin => internal}/ExecutableImage.java (98%) rename jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/{plugin/PostProcessorPlugin.java => internal/PostProcessor.java} (86%) delete mode 100644 jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/TransformerPlugin.java diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/Jlink.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/Jlink.java index e899d378963..1a23e19fa2b 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/Jlink.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/Jlink.java @@ -32,10 +32,10 @@ import java.util.List; import java.util.Map; import java.util.Objects; import java.util.Set; +import jdk.tools.jlink.internal.ExecutableImage; import jdk.tools.jlink.internal.JlinkTask; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.builder.ImageBuilder; import jdk.tools.jlink.internal.PluginRepository; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/DefaultImageBuilder.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/DefaultImageBuilder.java index 2c0620a99db..804b1da794e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/DefaultImageBuilder.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/DefaultImageBuilder.java @@ -57,7 +57,7 @@ import java.util.Set; import jdk.tools.jlink.internal.BasicImageWriter; import jdk.tools.jlink.internal.plugins.FileCopierPlugin; import jdk.tools.jlink.internal.plugins.FileCopierPlugin.SymImageFile; -import jdk.tools.jlink.plugin.ExecutableImage; +import jdk.tools.jlink.internal.ExecutableImage; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.PluginException; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/ImageBuilder.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/ImageBuilder.java index 10cea85d363..18339b9682f 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/ImageBuilder.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/builder/ImageBuilder.java @@ -27,7 +27,7 @@ package jdk.tools.jlink.builder; import java.io.DataOutputStream; import java.util.Properties; -import jdk.tools.jlink.plugin.ExecutableImage; +import jdk.tools.jlink.internal.ExecutableImage; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/ExecutableImage.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ExecutableImage.java similarity index 98% rename from jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/ExecutableImage.java rename to jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ExecutableImage.java index 499d23dd450..1e788e0ce1d 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/ExecutableImage.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ExecutableImage.java @@ -22,7 +22,7 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.tools.jlink.plugin; +package jdk.tools.jlink.internal; import java.nio.file.Path; import java.util.List; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java index d492c09f1d5..339b4d3d558 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImageFileCreator.java @@ -43,7 +43,6 @@ import java.util.stream.Stream; import jdk.tools.jlink.internal.Archive.Entry; import jdk.tools.jlink.internal.Archive.Entry.EntryType; import jdk.tools.jlink.internal.ModulePoolImpl.CompressedModuleData; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModuleEntry; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java index a5bd7bf41f8..37064ec13d8 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java @@ -32,15 +32,12 @@ import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.Map.Entry; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.builder.ImageBuilder; import jdk.tools.jlink.Jlink; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.Plugin.Category; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.PostProcessorPlugin; -import jdk.tools.jlink.plugin.TransformerPlugin; /** * Plugins configuration. @@ -85,7 +82,7 @@ public final class ImagePluginConfiguration { + " added more than once to stack "); } seen.add(plug.getName()); - Category category = Utils.getCategory(plug); + Category category = plug.getType(); if (category == null) { throw new PluginException("Invalid category for " + plug.getName()); @@ -94,26 +91,13 @@ public final class ImagePluginConfiguration { lst.add(plug); } - List transformerPlugins = new ArrayList<>(); - List postProcessingPlugins = new ArrayList<>(); + List orderedPlugins = new ArrayList<>(); plugins.entrySet().stream().forEach((entry) -> { // Sort according to plugin constraints - List orderedPlugins = PluginOrderingGraph.sort(entry.getValue()); - Category category = entry.getKey(); - orderedPlugins.stream().forEach((p) -> { - if (category.isPostProcessor()) { - @SuppressWarnings("unchecked") - PostProcessorPlugin pp = (PostProcessorPlugin) p; - postProcessingPlugins.add(pp); - } else { - @SuppressWarnings("unchecked") - TransformerPlugin trans = (TransformerPlugin) p; - transformerPlugins.add(trans); - } - }); + orderedPlugins.addAll(PluginOrderingGraph.sort(entry.getValue())); }); Plugin lastSorter = null; - for (Plugin plugin : transformerPlugins) { + for (Plugin plugin : orderedPlugins) { if (plugin.getName().equals(pluginsConfiguration.getLastSorterPluginName())) { lastSorter = plugin; break; @@ -145,7 +129,6 @@ public final class ImagePluginConfiguration { }; } - return new ImagePluginStack(builder, transformerPlugins, - lastSorter, postProcessingPlugins); + return new ImagePluginStack(builder, orderedPlugins, lastSorter); } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java index 7d3dd182739..b8f44d84906 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginStack.java @@ -44,14 +44,11 @@ import java.util.stream.Stream; import jdk.internal.jimage.decompressor.Decompressor; import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.builder.ImageBuilder; -import jdk.tools.jlink.plugin.TransformerPlugin; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.LinkModule; import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.PostProcessorPlugin; /** * Plugins Stack. Plugins entry point to apply transformations onto resources @@ -161,42 +158,34 @@ public final class ImagePluginStack { private final ImageBuilder imageBuilder; private final Plugin lastSorter; - private final List contentPlugins = new ArrayList<>(); - private final List postProcessingPlugins = new ArrayList<>(); + private final List plugins = new ArrayList<>(); private final List resourcePrevisitors = new ArrayList<>(); public ImagePluginStack() { - this(null, Collections.emptyList(), null, - Collections.emptyList()); + this(null, Collections.emptyList(), null); } public ImagePluginStack(ImageBuilder imageBuilder, - List contentPlugins, - Plugin lastSorter, - List postprocessingPlugins) { + List plugins, + Plugin lastSorter) { this.imageBuilder = Objects.requireNonNull(imageBuilder); this.lastSorter = lastSorter; - Objects.requireNonNull(contentPlugins); - Objects.requireNonNull(postprocessingPlugins); - contentPlugins.stream().forEach((p) -> { + this.plugins.addAll(Objects.requireNonNull(plugins)); + plugins.stream().forEach((p) -> { Objects.requireNonNull(p); if (p instanceof ResourcePrevisitor) { resourcePrevisitors.add((ResourcePrevisitor) p); } - this.contentPlugins.add(p); - }); - postprocessingPlugins.stream().forEach((p) -> { - Objects.requireNonNull(p); - this.postProcessingPlugins.add(p); }); } public void operate(ImageProvider provider) throws Exception { ExecutableImage img = provider.retrieve(this); List arguments = new ArrayList<>(); - postProcessingPlugins.stream() - .map((plugin) -> plugin.process(img)) + plugins.stream() + .filter(PostProcessor.class::isInstance) + .map((plugin) -> ((PostProcessor)plugin).process(img)) .filter((lst) -> (lst != null)) .forEach((lst) -> { arguments.addAll(lst); @@ -241,7 +230,7 @@ public final class ImagePluginStack { ModulePoolImpl current = resources; List frozenOrder = null; - for (TransformerPlugin p : contentPlugins) { + for (Plugin p : plugins) { current.setReadOnly(); ModulePoolImpl output = null; if (p == lastSorter) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java index c6732081cf1..396fb315101 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/JlinkTask.java @@ -49,7 +49,6 @@ import static jdk.tools.jlink.internal.TaskHelper.JLINK_BUNDLE; import jdk.tools.jlink.internal.TaskHelper.Option; import jdk.tools.jlink.internal.TaskHelper.OptionsHelper; import jdk.tools.jlink.internal.ImagePluginStack.ImageProvider; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.Jlink.JlinkConfiguration; import jdk.tools.jlink.Jlink.PluginsConfiguration; import jdk.tools.jlink.plugin.PluginException; @@ -184,8 +183,8 @@ public class JlinkTask { optionsHelper.showHelp(PROGNAME); return EXIT_OK; } - if (optionsHelper.listPlugins()) { - optionsHelper.listPlugins(true); + if (optionsHelper.shouldListPlugins()) { + optionsHelper.listPlugins(); return EXIT_OK; } if (options.version || options.fullVersion) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginRepository.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginRepository.java index e4dd7b3bd1c..6a7af972a83 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginRepository.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginRepository.java @@ -34,8 +34,6 @@ import java.util.Objects; import java.util.ServiceLoader; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.PostProcessorPlugin; -import jdk.tools.jlink.plugin.TransformerPlugin; /** * @@ -59,17 +57,7 @@ public final class PluginRepository { */ public static Plugin getPlugin(String name, Layer pluginsLayer) { - Plugin tp = getPlugin(TransformerPlugin.class, name, pluginsLayer); - Plugin ppp = getPlugin(PostProcessorPlugin.class, name, pluginsLayer); - - // We should not have a transformer plugin and a post processor plugin - // of the same name. That kind of duplicate is detected here. - if (tp != null && ppp != null) { - throw new PluginException("Multiple plugin " - + "for the name " + name); - } - - return tp != null? tp : ppp; + return getPlugin(Plugin.class, name, pluginsLayer); } /** @@ -112,10 +100,7 @@ public final class PluginRepository { } public static List getPlugins(Layer pluginsLayer) { - List plugins = new ArrayList<>(); - plugins.addAll(getPlugins(TransformerPlugin.class, pluginsLayer)); - plugins.addAll(getPlugins(PostProcessorPlugin.class, pluginsLayer)); - return plugins; + return getPlugins(Plugin.class, pluginsLayer); } private static T getPlugin(Class clazz, String name, @@ -138,10 +123,10 @@ public final class PluginRepository { } /** - * The post processors accessible in the current context. + * The plugins accessible in the current context. * * @param pluginsLayer - * @return The list of post processors. + * @return The list of plugins. */ private static List getPlugins(Class clazz, Layer pluginsLayer) { Objects.requireNonNull(pluginsLayer); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/PostProcessorPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PostProcessor.java similarity index 86% rename from jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/PostProcessorPlugin.java rename to jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PostProcessor.java index 7483a5e76f6..7eda42eb384 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/PostProcessorPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PostProcessor.java @@ -22,15 +22,15 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.tools.jlink.plugin; +package jdk.tools.jlink.internal; import java.util.List; /** - * Implement this interface to develop a PostProcessor plugin. - * PostProcessor plugins are called once the image has been generated and is executable. + * Plugin wishing to post-proces must implement this interface. PostProcessors + * are called once the image has been generated and is executable. **/ -public interface PostProcessorPlugin extends Plugin { +public interface PostProcessor { /** * Post process an image. diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java index eed739da19b..01c15f5ec2e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/TaskHelper.java @@ -428,7 +428,7 @@ public final class TaskHelper { return opt.hasArg; } - public boolean listPlugins() { + public boolean shouldListPlugins() { return pluginOptions.listPlugins; } @@ -570,26 +570,19 @@ public final class TaskHelper { log.println(bundleHelper.getMessage("main.command.files")); } - public void listPlugins(boolean showsImageBuilder) { + public void listPlugins() { log.println("\n" + bundleHelper.getMessage("main.extended.help")); List pluginList = PluginRepository. getPlugins(pluginOptions.pluginsLayer); - for (Plugin plugin : Utils. - getSortedPreProcessors(pluginList)) { - showPlugin(plugin, log, showsImageBuilder); - } - - if (showsImageBuilder) { - for (Plugin plugin : Utils.getSortedPostProcessors(pluginList)) { - showPlugin(plugin, log, showsImageBuilder); - } + for (Plugin plugin : Utils.getSortedPlugins(pluginList)) { + showPlugin(plugin, log); } log.println("\n" + bundleHelper.getMessage("main.extended.help.footer")); } - private void showPlugin(Plugin plugin, PrintWriter log, boolean showsImageBuilder) { - if (showsPlugin(plugin, showsImageBuilder)) { + private void showPlugin(Plugin plugin, PrintWriter log) { + if (showsPlugin(plugin)) { log.println("\n" + bundleHelper.getMessage("main.plugin.name") + ": " + plugin.getName()); @@ -599,7 +592,7 @@ public final class TaskHelper { + ": " + plugin.getClass().getName()); log.println(bundleHelper.getMessage("main.plugin.module") + ": " + plugin.getClass().getModule().getName()); - Category category = Utils.getCategory(plugin); + Category category = plugin.getType(); log.println(bundleHelper.getMessage("main.plugin.category") + ": " + category.getName()); log.println(bundleHelper.getMessage("main.plugin.state") @@ -722,14 +715,8 @@ public final class TaskHelper { } } - // Display all plugins or pre processors only. - private static boolean showsPlugin(Plugin plugin, boolean showsImageBuilder) { - if (!Utils.isDisabled(plugin) && plugin.getOption() != null) { - if (Utils.isPostProcessor(plugin) && !showsImageBuilder) { - return false; - } - return true; - } - return false; + // Display all plugins + private static boolean showsPlugin(Plugin plugin) { + return (!Utils.isDisabled(plugin) && plugin.getOption() != null); } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java index 7a166e1c82c..ef8fb392086 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/Utils.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -55,51 +55,10 @@ public class Utils { .collect(Collectors.toList()); } - public static boolean isPostProcessor(Plugin provider) { - return provider.getType().isPostProcessor(); - } - public static boolean isPreProcessor(Plugin provider) { - return !isPostProcessor(provider); - } - - public static Category getCategory(Plugin provider) { - return provider.getType(); - } - - public static List getPreProcessors(List plugins) { + public static List getSortedPlugins(List plugins) { List res = new ArrayList<>(); - for (Plugin p : plugins) { - if (isPreProcessor(p)) { - res.add(p); - } - } - return res; - } - - public static List getPostProcessors(List plugins) { - List res = new ArrayList<>(); - for (Plugin p : plugins) { - if (isPostProcessor(p)) { - res.add(p); - } - } - return res; - } - - public static List getSortedPostProcessors(List plugins) { - List res = getPostProcessors(plugins); - res.sort(new Comparator() { - @Override - public int compare(Plugin o1, Plugin o2) { - return o1.getName().compareTo(o2.getName()); - } - }); - return res; - } - - public static List getSortedPreProcessors(List plugins) { - List res = getPreProcessors(plugins); + res.addAll(plugins); res.sort(new Comparator() { @Override public int compare(Plugin o1, Plugin o2) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java index bc753cfb8cd..75fb2f12c9e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/DefaultCompressPlugin.java @@ -28,7 +28,7 @@ import java.util.Map; import jdk.tools.jlink.internal.ModulePoolImpl; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.internal.ImagePluginStack; import jdk.tools.jlink.internal.ResourcePrevisitor; import jdk.tools.jlink.internal.StringTable; @@ -37,7 +37,7 @@ import jdk.tools.jlink.internal.StringTable; * * ZIP and String Sharing compression plugin */ -public final class DefaultCompressPlugin implements TransformerPlugin, ResourcePrevisitor { +public final class DefaultCompressPlugin implements Plugin, ResourcePrevisitor { public static final String NAME = "compress"; public static final String FILTER = "filter"; public static final String LEVEL_0 = "0"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java index b243ce684ef..fb7826cd6ce 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeFilesPlugin.java @@ -26,7 +26,7 @@ package jdk.tools.jlink.internal.plugins; import java.util.Map; import java.util.function.Predicate; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; @@ -34,7 +34,7 @@ import jdk.tools.jlink.plugin.ModuleEntry; * * Exclude files plugin */ -public final class ExcludeFilesPlugin implements TransformerPlugin { +public final class ExcludeFilesPlugin implements Plugin { public static final String NAME = "exclude-files"; private Predicate predicate; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java index d193473197e..f244d6d8252 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludePlugin.java @@ -26,7 +26,7 @@ package jdk.tools.jlink.internal.plugins; import java.util.Map; import java.util.function.Predicate; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; @@ -34,7 +34,7 @@ import jdk.tools.jlink.plugin.ModulePool; * * Exclude resources plugin */ -public final class ExcludePlugin implements TransformerPlugin { +public final class ExcludePlugin implements Plugin { public static final String NAME = "exclude-resources"; private Predicate predicate; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java index 8553e1a4026..278106d9236 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ExcludeVMPlugin.java @@ -35,7 +35,7 @@ import java.util.Map; import java.util.TreeSet; import java.util.function.Predicate; import java.util.stream.Collectors; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.PluginException; @@ -44,7 +44,7 @@ import jdk.tools.jlink.plugin.PluginException; * * Exclude VM plugin */ -public final class ExcludeVMPlugin implements TransformerPlugin { +public final class ExcludeVMPlugin implements Plugin { private static final class JvmComparator implements Comparator { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java index 195b596bf72..51db055cad9 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/FileCopierPlugin.java @@ -41,14 +41,14 @@ import jdk.tools.jlink.internal.PathModuleEntry; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.internal.Utils; /** * * Copy files to image from various locations. */ -public class FileCopierPlugin implements TransformerPlugin { +public class FileCopierPlugin implements Plugin { public static final String NAME = "copy-files"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java index b9a60ad564a..40eb349748d 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/GenerateJLIClassesPlugin.java @@ -34,12 +34,12 @@ import java.util.stream.Collectors; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * Plugin to generate java.lang.invoke classes. */ -public final class GenerateJLIClassesPlugin implements TransformerPlugin { +public final class GenerateJLIClassesPlugin implements Plugin { private static final String NAME = "generate-jli-classes"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java index fd7a37cf7b0..18a77753d2e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/IncludeLocalesPlugin.java @@ -44,7 +44,7 @@ import jdk.tools.jlink.plugin.LinkModule; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * Plugin to explicitly specify the locale data included in jdk.localedata @@ -68,7 +68,7 @@ import jdk.tools.jlink.plugin.TransformerPlugin; * start with at least one white space character, e.g., " ar ar-EG ..." * ^ */ -public final class IncludeLocalesPlugin implements TransformerPlugin, ResourcePrevisitor { +public final class IncludeLocalesPlugin implements Plugin, ResourcePrevisitor { public static final String NAME = "include-locales"; private static final String MODULENAME = "jdk.localedata"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java index ac67a5f6413..069be950c0b 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OrderResourcesPlugin.java @@ -37,14 +37,14 @@ import java.util.function.ToIntFunction; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.internal.Utils; /** * * Order Resources plugin */ -public final class OrderResourcesPlugin implements TransformerPlugin { +public final class OrderResourcesPlugin implements Plugin { public static final String NAME = "order-resources"; private static final FileSystem JRT_FILE_SYSTEM = Utils.jrtFileSystem(); diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java index 155243a2ebd..e47094ce1c4 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ReleaseInfoPlugin.java @@ -36,12 +36,12 @@ import jdk.tools.jlink.internal.Utils; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.Plugin.Category; import jdk.tools.jlink.plugin.Plugin.State; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * This plugin adds/deletes information for 'release' file. */ -public final class ReleaseInfoPlugin implements TransformerPlugin { +public final class ReleaseInfoPlugin implements Plugin { // option name public static final String NAME = "release-info"; public static final String KEYS = "keys"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java index 98cccd12051..97bd3a27413 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StringSharingPlugin.java @@ -56,7 +56,7 @@ import jdk.internal.jimage.decompressor.CompressIndexes; import jdk.internal.jimage.decompressor.SignatureParser; import jdk.internal.jimage.decompressor.StringSharingDecompressor; import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; @@ -68,7 +68,7 @@ import jdk.tools.jlink.internal.StringTable; * A Plugin that stores the image classes constant pool UTF_8 entries into the * Image StringsTable. */ -public class StringSharingPlugin implements TransformerPlugin, ResourcePrevisitor { +public class StringSharingPlugin implements Plugin, ResourcePrevisitor { public static final String NAME = "compact-cp"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java index 65eb1bb7404..325ec506301 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripDebugPlugin.java @@ -29,13 +29,13 @@ import jdk.internal.org.objectweb.asm.ClassReader; import jdk.internal.org.objectweb.asm.ClassWriter; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * * Strip debug attributes plugin */ -public final class StripDebugPlugin implements TransformerPlugin { +public final class StripDebugPlugin implements Plugin { public static final String NAME = "strip-debug"; private final Predicate predicate; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java index f70af29558a..4c3b7dc7950 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/StripNativeCommandsPlugin.java @@ -26,13 +26,13 @@ package jdk.tools.jlink.internal.plugins; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * * Strip Native Commands plugin */ -public final class StripNativeCommandsPlugin implements TransformerPlugin { +public final class StripNativeCommandsPlugin implements Plugin { public static final String NAME = "strip-native-commands"; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/SystemModuleDescriptorPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/SystemModuleDescriptorPlugin.java index cc140664183..f12adb9af16 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/SystemModuleDescriptorPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/SystemModuleDescriptorPlugin.java @@ -52,7 +52,7 @@ import jdk.internal.org.objectweb.asm.Opcodes; import static jdk.internal.org.objectweb.asm.Opcodes.*; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.internal.plugins.SystemModuleDescriptorPlugin.Builder.*; import jdk.tools.jlink.plugin.ModuleEntry; @@ -67,7 +67,7 @@ import jdk.tools.jlink.plugin.ModuleEntry; * @see java.lang.module.SystemModuleFinder * @see SystemModules */ -public final class SystemModuleDescriptorPlugin implements TransformerPlugin { +public final class SystemModuleDescriptorPlugin implements Plugin { private static final JavaLangModuleAccess JLMA = SharedSecrets.getJavaLangModuleAccess(); // TODO: packager has the dependency on the plugin name diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java index 366ac079f4c..84c24559012 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ZipPlugin.java @@ -34,13 +34,13 @@ import java.util.zip.Deflater; import jdk.tools.jlink.internal.ModulePoolImpl; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * * ZIP Compression plugin */ -public final class ZipPlugin implements TransformerPlugin { +public final class ZipPlugin implements Plugin { public static final String NAME = "zip"; private Predicate predicate; diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java index 52712172d5e..d99ec7bfcb5 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java @@ -25,7 +25,7 @@ package jdk.tools.jlink.internal.plugins.asm; import java.util.Objects; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.internal.ModulePoolImpl; @@ -35,7 +35,7 @@ import jdk.tools.jlink.internal.ModulePoolImpl; * resources. * */ -public abstract class AsmPlugin implements TransformerPlugin { +public abstract class AsmPlugin implements Plugin { public AsmPlugin() { } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java index f748fa0f286..b83d5036954 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java @@ -57,29 +57,19 @@ public interface Plugin { SORTER("SORTER"), COMPRESSOR("COMPRESSOR"), METAINFO_ADDER("METAINFO_ADDER"), - VERIFIER("VERIFIER", true), - PROCESSOR("PROCESSOR", true), - PACKAGER("PACKAGER", true); + VERIFIER("VERIFIER"), + PROCESSOR("PROCESSOR"), + PACKAGER("PACKAGER"); private final String name; - private final boolean postProcessor; - - Category(String name, boolean postProcessor) { - this.name = name; - this.postProcessor = postProcessor; - } Category(String name) { - this(name, false); + this.name = name; } public String getName() { return name; } - - public boolean isPostProcessor() { - return postProcessor; - } } /** @@ -209,4 +199,15 @@ public interface Plugin { */ public default void configure(Map config) { } + + /** + * Visit the content of the modules that are composing the image. + * + * @param in Read only content. + * @param out The pool to fill with content. This pool must contain + * the result of the visit. + * + * @throws PluginException + */ + public void visit(ModulePool in, ModulePool out); } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/TransformerPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/TransformerPlugin.java deleted file mode 100644 index 15133221c43..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/TransformerPlugin.java +++ /dev/null @@ -1,44 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code 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 - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.plugin; - - -/** - * Implement this interface to develop a Transformer plugin. - * TransformerPlugin are called during image creation. This kind of plugin aims to - * modify the content of the runtime image. - */ -public interface TransformerPlugin extends Plugin { - /** - * Visit the content of the modules that are composing the image. - * - * @param in Read only content. - * @param out The pool to fill with content. This pool must contain - * the result of the visit. - * - * @throws PluginException - */ - public void visit(ModulePool in, ModulePool out); -} diff --git a/jdk/src/jdk.jlink/share/classes/module-info.java b/jdk/src/jdk.jlink/share/classes/module-info.java index c23116404ac..b2ce1fd94bd 100644 --- a/jdk/src/jdk.jlink/share/classes/module-info.java +++ b/jdk/src/jdk.jlink/share/classes/module-info.java @@ -29,20 +29,19 @@ module jdk.jlink { requires jdk.internal.opt; requires jdk.jdeps; - uses jdk.tools.jlink.plugin.TransformerPlugin; - uses jdk.tools.jlink.plugin.PostProcessorPlugin; + uses jdk.tools.jlink.plugin.Plugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.FileCopierPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.StripDebugPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.ExcludePlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.ExcludeFilesPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.SystemModuleDescriptorPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.StripNativeCommandsPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.OrderResourcesPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.OptimizationPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.ExcludeVMPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.IncludeLocalesPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.GenerateJLIClassesPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with jdk.tools.jlink.internal.plugins.ReleaseInfoPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.FileCopierPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.StripDebugPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ExcludePlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ExcludeFilesPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.SystemModuleDescriptorPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.StripNativeCommandsPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.OrderResourcesPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.OptimizationPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ExcludeVMPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.IncludeLocalesPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.GenerateJLIClassesPlugin; + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ReleaseInfoPlugin; } diff --git a/jdk/test/tools/jlink/DefaultProviderTest.java b/jdk/test/tools/jlink/DefaultProviderTest.java index 9f4229a3451..7d8d43bce9e 100644 --- a/jdk/test/tools/jlink/DefaultProviderTest.java +++ b/jdk/test/tools/jlink/DefaultProviderTest.java @@ -33,7 +33,6 @@ import jdk.tools.jlink.internal.PluginRepository; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.PluginException; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; import tests.Helper; /* @@ -60,7 +59,7 @@ public class DefaultProviderTest { expectedOptions.put("option2", "value2"); } - private static class Custom implements TransformerPlugin { + private static class Custom implements Plugin { private boolean enabled = true; @Override diff --git a/jdk/test/tools/jlink/ImageFileCreatorTest.java b/jdk/test/tools/jlink/ImageFileCreatorTest.java index 8e093c69459..c81888c7dfa 100644 --- a/jdk/test/tools/jlink/ImageFileCreatorTest.java +++ b/jdk/test/tools/jlink/ImageFileCreatorTest.java @@ -37,7 +37,7 @@ import java.util.stream.Stream; import jdk.tools.jlink.internal.Archive; import jdk.tools.jlink.internal.ImageFileCreator; import jdk.tools.jlink.internal.ImagePluginStack; -import jdk.tools.jlink.plugin.ExecutableImage; +import jdk.tools.jlink.internal.ExecutableImage; import jdk.tools.jlink.builder.ImageBuilder; import jdk.tools.jlink.plugin.ModulePool; @@ -220,7 +220,7 @@ public class ImageFileCreatorTest { }; ImagePluginStack stack = new ImagePluginStack(noopBuilder, Collections.emptyList(), - null, Collections.emptyList()); + null); ImageFileCreator.create(archives, ByteOrder.nativeOrder(), stack); } diff --git a/jdk/test/tools/jlink/IntegrationTest.java b/jdk/test/tools/jlink/IntegrationTest.java index e321b08ffa4..0eb82a0415e 100644 --- a/jdk/test/tools/jlink/IntegrationTest.java +++ b/jdk/test/tools/jlink/IntegrationTest.java @@ -34,17 +34,17 @@ import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; +import java.util.function.Function; import jdk.tools.jlink.Jlink; import jdk.tools.jlink.Jlink.JlinkConfiguration; import jdk.tools.jlink.Jlink.PluginsConfiguration; import jdk.tools.jlink.builder.DefaultImageBuilder; -import jdk.tools.jlink.plugin.ExecutableImage; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.PostProcessorPlugin; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; +import jdk.tools.jlink.internal.ExecutableImage; +import jdk.tools.jlink.internal.PostProcessor; import jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; import jdk.tools.jlink.internal.plugins.StripDebugPlugin; -import jdk.tools.jlink.plugin.Plugin; import tests.Helper; import tests.JImageGenerator; @@ -70,7 +70,7 @@ public class IntegrationTest { private static final List ordered = new ArrayList<>(); - public static class MyPostProcessor implements PostProcessorPlugin { + public static class MyPostProcessor implements PostProcessor, Plugin { public static final String NAME = "mypostprocessor"; @@ -98,9 +98,14 @@ public class IntegrationTest { public void configure(Map config) { throw new UnsupportedOperationException("Shouldn't be called"); } + + @Override + public void visit(ModulePool in, ModulePool out) { + in.transformAndCopy(Function.identity(), out); + } } - public static class MyPlugin1 implements TransformerPlugin { + public static class MyPlugin1 implements Plugin { Integer index; Set after; diff --git a/jdk/test/tools/jlink/JLinkOptionsTest.java b/jdk/test/tools/jlink/JLinkOptionsTest.java index 565c58bffa9..ea384f508a2 100644 --- a/jdk/test/tools/jlink/JLinkOptionsTest.java +++ b/jdk/test/tools/jlink/JLinkOptionsTest.java @@ -26,7 +26,7 @@ import java.util.Map; import java.util.Set; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.internal.PluginRepository; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import tests.Helper; @@ -46,7 +46,7 @@ import tests.Helper; */ public class JLinkOptionsTest { - private static class TestPlugin implements TransformerPlugin { + private static class TestPlugin implements Plugin { private final String name; private final String option; diff --git a/jdk/test/tools/jlink/JLinkPostProcessingTest.java b/jdk/test/tools/jlink/JLinkPostProcessingTest.java index c6da5dd97cc..cee0b5c4d08 100644 --- a/jdk/test/tools/jlink/JLinkPostProcessingTest.java +++ b/jdk/test/tools/jlink/JLinkPostProcessingTest.java @@ -28,10 +28,13 @@ import java.nio.file.Path; import java.util.Collections; import java.util.List; import java.util.Map; +import java.util.function.Function; +import jdk.tools.jlink.plugin.Plugin; +import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.internal.PluginRepository; -import jdk.tools.jlink.plugin.ExecutableImage; -import jdk.tools.jlink.plugin.PostProcessorPlugin; +import jdk.tools.jlink.internal.PostProcessor; +import jdk.tools.jlink.internal.ExecutableImage; import tests.Helper; /* @@ -50,7 +53,7 @@ import tests.Helper; */ public class JLinkPostProcessingTest { - private static class PPPlugin implements PostProcessorPlugin { + private static class PPPlugin implements PostProcessor, Plugin { private static ExecutableImage called; private static final String NAME = "pp"; @@ -67,6 +70,11 @@ public class JLinkPostProcessingTest { return null; } + @Override + public void visit(ModulePool in, ModulePool out) { + in.transformAndCopy(Function.identity(), out); + } + @Override public String getName() { return NAME; diff --git a/jdk/test/tools/jlink/JLinkTest.java b/jdk/test/tools/jlink/JLinkTest.java index 19b6e6a59d9..bf1a31d95a8 100644 --- a/jdk/test/tools/jlink/JLinkTest.java +++ b/jdk/test/tools/jlink/JLinkTest.java @@ -35,7 +35,6 @@ import java.util.List; import java.util.stream.Stream; import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.plugin.TransformerPlugin; import jdk.tools.jlink.internal.PluginRepository; import tests.Helper; import tests.JImageGenerator; @@ -60,7 +59,7 @@ public class JLinkTest { private static int getNumJlinkPlugins() { ModuleDescriptor desc = Plugin.class.getModule().getDescriptor(); return desc.provides(). - get(TransformerPlugin.class.getName()). + get(Plugin.class.getName()). providers().size(); } diff --git a/jdk/test/tools/jlink/customplugin/module-info.java b/jdk/test/tools/jlink/customplugin/module-info.java index 63e227544ba..4b51ff86769 100644 --- a/jdk/test/tools/jlink/customplugin/module-info.java +++ b/jdk/test/tools/jlink/customplugin/module-info.java @@ -23,6 +23,6 @@ module customplugin { requires jdk.jlink; - provides jdk.tools.jlink.plugin.TransformerPlugin with plugin.HelloPlugin; - provides jdk.tools.jlink.plugin.TransformerPlugin with plugin.CustomPlugin; + provides jdk.tools.jlink.plugin.Plugin with plugin.HelloPlugin; + provides jdk.tools.jlink.plugin.Plugin with plugin.CustomPlugin; } diff --git a/jdk/test/tools/jlink/customplugin/plugin/CustomPlugin.java b/jdk/test/tools/jlink/customplugin/plugin/CustomPlugin.java index 1b8b16b515b..45d54e8092b 100644 --- a/jdk/test/tools/jlink/customplugin/plugin/CustomPlugin.java +++ b/jdk/test/tools/jlink/customplugin/plugin/CustomPlugin.java @@ -27,9 +27,9 @@ import java.util.Map; import java.util.function.Function; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; -public class CustomPlugin implements TransformerPlugin { +public class CustomPlugin implements Plugin { private final static String NAME = "custom-plugin"; diff --git a/jdk/test/tools/jlink/customplugin/plugin/HelloPlugin.java b/jdk/test/tools/jlink/customplugin/plugin/HelloPlugin.java index e37dee780d9..365544e7a39 100644 --- a/jdk/test/tools/jlink/customplugin/plugin/HelloPlugin.java +++ b/jdk/test/tools/jlink/customplugin/plugin/HelloPlugin.java @@ -29,12 +29,12 @@ import java.util.Collections; import java.util.Map; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; /** * Custom plugin */ -public final class HelloPlugin implements TransformerPlugin { +public final class HelloPlugin implements Plugin { private static final String OUTPUT_FILE = "customplugin.txt"; public static final String NAME = "hello"; diff --git a/jdk/test/tools/jlink/plugins/CompressorPluginTest.java b/jdk/test/tools/jlink/plugins/CompressorPluginTest.java index ff616caa53c..43a25b0318f 100644 --- a/jdk/test/tools/jlink/plugins/CompressorPluginTest.java +++ b/jdk/test/tools/jlink/plugins/CompressorPluginTest.java @@ -61,7 +61,6 @@ import jdk.tools.jlink.internal.plugins.ZipPlugin; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class CompressorPluginTest { @@ -279,9 +278,8 @@ public class CompressorPluginTest { ModulePoolImpl inputResources, ModuleEntry res, List includesPatterns) { - TransformerPlugin compressor = (TransformerPlugin) plugin; ModulePool compressedModulePool = new ModulePoolImpl(ByteOrder.nativeOrder(), inputResources.getStringTable()); - compressor.visit(inputResources, compressedModulePool); + plugin.visit(inputResources, compressedModulePool); String path = res.getPath(); ModuleEntry compressed = compressedModulePool.findEntry(path).get(); CompressedResourceHeader header diff --git a/jdk/test/tools/jlink/plugins/ExcludeFilesPluginTest.java b/jdk/test/tools/jlink/plugins/ExcludeFilesPluginTest.java index b85d40e53e3..edc5d52a0fd 100644 --- a/jdk/test/tools/jlink/plugins/ExcludeFilesPluginTest.java +++ b/jdk/test/tools/jlink/plugins/ExcludeFilesPluginTest.java @@ -40,7 +40,6 @@ import jdk.tools.jlink.internal.ModulePoolImpl; import jdk.tools.jlink.internal.plugins.ExcludeFilesPlugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class ExcludeFilesPluginTest { public static void main(String[] args) throws Exception { diff --git a/jdk/test/tools/jlink/plugins/ExcludeVMPluginTest.java b/jdk/test/tools/jlink/plugins/ExcludeVMPluginTest.java index d4e3b48afc9..03f453fda42 100644 --- a/jdk/test/tools/jlink/plugins/ExcludeVMPluginTest.java +++ b/jdk/test/tools/jlink/plugins/ExcludeVMPluginTest.java @@ -38,7 +38,6 @@ import jdk.tools.jlink.internal.plugins.ExcludeVMPlugin; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModulePool; import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.TransformerPlugin; public class ExcludeVMPluginTest { @@ -173,7 +172,7 @@ public class ExcludeVMPluginTest { } ModulePool out = new ModulePoolImpl(); - TransformerPlugin p = new ExcludeVMPlugin(); + Plugin p = new ExcludeVMPlugin(); Map config = new HashMap<>(); if (vm != null) { config.put(ExcludeVMPlugin.NAME, vm); diff --git a/jdk/test/tools/jlink/plugins/LastSorterTest.java b/jdk/test/tools/jlink/plugins/LastSorterTest.java index a15284dafa9..3f02c5172a6 100644 --- a/jdk/test/tools/jlink/plugins/LastSorterTest.java +++ b/jdk/test/tools/jlink/plugins/LastSorterTest.java @@ -45,7 +45,6 @@ import jdk.tools.jlink.Jlink.PluginsConfiguration; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class LastSorterTest { @@ -167,7 +166,7 @@ public class LastSorterTest { } } - public static class SorterPlugin implements TransformerPlugin { + public static class SorterPlugin implements Plugin { private final String name; private String starts; diff --git a/jdk/test/tools/jlink/plugins/OrderResourcesPluginTest.java b/jdk/test/tools/jlink/plugins/OrderResourcesPluginTest.java index 5fc96d69d36..5cb5519bb63 100644 --- a/jdk/test/tools/jlink/plugins/OrderResourcesPluginTest.java +++ b/jdk/test/tools/jlink/plugins/OrderResourcesPluginTest.java @@ -42,7 +42,7 @@ import jdk.tools.jlink.internal.ModulePoolImpl; import jdk.tools.jlink.internal.plugins.OrderResourcesPlugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; public class OrderResourcesPluginTest { @@ -93,7 +93,7 @@ public class OrderResourcesPluginTest { ModulePool out = new ModulePoolImpl(); Map config = new HashMap<>(); config.put(OrderResourcesPlugin.NAME, "/zazou/**,**/module-info.class"); - TransformerPlugin p = new OrderResourcesPlugin(); + Plugin p = new OrderResourcesPlugin(); p.configure(config); p.visit(resources, out); check(out.entries().collect(Collectors.toList()), sorted); @@ -116,7 +116,7 @@ public class OrderResourcesPluginTest { ModulePool out = new ModulePoolImpl(); Map config = new HashMap<>(); config.put(OrderResourcesPlugin.NAME, "@" + order.getAbsolutePath()); - TransformerPlugin p = new OrderResourcesPlugin(); + Plugin p = new OrderResourcesPlugin(); p.configure(config); p.visit(resources, out); check(out.entries().collect(Collectors.toList()), sorted2); diff --git a/jdk/test/tools/jlink/plugins/PluginOrderTest.java b/jdk/test/tools/jlink/plugins/PluginOrderTest.java index 18178145e64..0116882c78f 100644 --- a/jdk/test/tools/jlink/plugins/PluginOrderTest.java +++ b/jdk/test/tools/jlink/plugins/PluginOrderTest.java @@ -46,7 +46,6 @@ import jdk.tools.jlink.internal.PluginOrderingGraph; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.Plugin.Category; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class PluginOrderTest { @@ -225,7 +224,7 @@ public class PluginOrderTest { PluginOrderingGraph.sort(plugins); } - private static class Plug implements TransformerPlugin { + private static class Plug implements Plugin { private final Set isBefore; private final Set isAfter; diff --git a/jdk/test/tools/jlink/plugins/PluginsNegativeTest.java b/jdk/test/tools/jlink/plugins/PluginsNegativeTest.java index 3b533556582..679a0d058a0 100644 --- a/jdk/test/tools/jlink/plugins/PluginsNegativeTest.java +++ b/jdk/test/tools/jlink/plugins/PluginsNegativeTest.java @@ -44,7 +44,6 @@ import jdk.tools.jlink.Jlink.PluginsConfiguration; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class PluginsNegativeTest { @@ -117,7 +116,7 @@ public class PluginsNegativeTest { } } - public static class CustomPlugin implements TransformerPlugin { + public static class CustomPlugin implements Plugin { private final String name; diff --git a/jdk/test/tools/jlink/plugins/PrevisitorTest.java b/jdk/test/tools/jlink/plugins/PrevisitorTest.java index 019470c375b..273706e4487 100644 --- a/jdk/test/tools/jlink/plugins/PrevisitorTest.java +++ b/jdk/test/tools/jlink/plugins/PrevisitorTest.java @@ -49,7 +49,6 @@ import jdk.tools.jlink.Jlink; import jdk.tools.jlink.plugin.Plugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; public class PrevisitorTest { @@ -107,7 +106,7 @@ public class PrevisitorTest { } } - private static class CustomPlugin implements TransformerPlugin, ResourcePrevisitor { + private static class CustomPlugin implements Plugin, ResourcePrevisitor { private static String NAME = "plugin"; diff --git a/jdk/test/tools/jlink/plugins/StringSharingPluginTest.java b/jdk/test/tools/jlink/plugins/StringSharingPluginTest.java index 58d63adcfd7..c8a93e0ed4b 100644 --- a/jdk/test/tools/jlink/plugins/StringSharingPluginTest.java +++ b/jdk/test/tools/jlink/plugins/StringSharingPluginTest.java @@ -57,7 +57,7 @@ import jdk.tools.jlink.internal.StringTable; import jdk.tools.jlink.internal.plugins.StringSharingPlugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import tests.Helper; import tests.JImageValidator; @@ -119,7 +119,7 @@ public class StringSharingPluginTest { try (java.util.stream.Stream stream = Files.walk(compiledClasses)) { stream.forEach(c); } - TransformerPlugin plugin = new StringSharingPlugin(); + Plugin plugin = new StringSharingPlugin(); ModulePoolImpl result = new ModulePoolImpl(resources.getByteOrder(), resources.getStringTable()); plugin.visit(resources, result); diff --git a/jdk/test/tools/jlink/plugins/StripDebugPluginTest.java b/jdk/test/tools/jlink/plugins/StripDebugPluginTest.java index d3617db6f8a..86459b1c5bd 100644 --- a/jdk/test/tools/jlink/plugins/StripDebugPluginTest.java +++ b/jdk/test/tools/jlink/plugins/StripDebugPluginTest.java @@ -58,7 +58,7 @@ import jdk.tools.jlink.internal.ModulePoolImpl; import jdk.tools.jlink.internal.plugins.StripDebugPlugin; import jdk.tools.jlink.plugin.ModuleEntry; import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.plugin.TransformerPlugin; +import jdk.tools.jlink.plugin.Plugin; import tests.Helper; public class StripDebugPluginTest { @@ -124,7 +124,7 @@ public class StripDebugPluginTest { checkDebugAttributes(result1.getBytes()); } - private ModuleEntry stripDebug(TransformerPlugin debug, ModuleEntry classResource, + private ModuleEntry stripDebug(Plugin debug, ModuleEntry classResource, String path, String infoPath, byte[] moduleInfo) throws Exception { ModulePool resources = new ModulePoolImpl(); resources.add(classResource); From 1add863d15ff349301d66522607372dae05c34cd Mon Sep 17 00:00:00 2001 From: Brent Christian Date: Thu, 30 Jun 2016 10:13:30 -0700 Subject: [PATCH 101/125] 8160370: System.getProperty("os.version") returns "Unknown" on Mac Read SystemVersion.plist on pre-10.9 Mac OS Reviewed-by: bpb, ddehaven, gziemski, rriggs --- .../macosx/native/libjava/java_props_macosx.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.base/macosx/native/libjava/java_props_macosx.c b/jdk/src/java.base/macosx/native/libjava/java_props_macosx.c index cbbfde4c2a7..ea3dc25c624 100644 --- a/jdk/src/java.base/macosx/native/libjava/java_props_macosx.c +++ b/jdk/src/java.base/macosx/native/libjava/java_props_macosx.c @@ -182,7 +182,17 @@ void setOSNameAndVersion(java_props_t *sprops) { // Copy out the char* osVersionCStr = strdup([nsVerStr UTF8String]); } - + // Fallback if running on pre-10.9 Mac OS + if (osVersionCStr == NULL) { + NSDictionary *version = [NSDictionary dictionaryWithContentsOfFile : + @"/System/Library/CoreServices/SystemVersion.plist"]; + if (version != NULL) { + NSString *nsVerStr = [version objectForKey : @"ProductVersion"]; + if (nsVerStr != NULL) { + osVersionCStr = strdup([nsVerStr UTF8String]); + } + } + } if (osVersionCStr == NULL) { osVersionCStr = strdup("Unknown"); } @@ -190,7 +200,9 @@ void setOSNameAndVersion(java_props_t *sprops) { } -static Boolean getProxyInfoForProtocol(CFDictionaryRef inDict, CFStringRef inEnabledKey, CFStringRef inHostKey, CFStringRef inPortKey, CFStringRef *outProxyHost, int *ioProxyPort) { +static Boolean getProxyInfoForProtocol(CFDictionaryRef inDict, CFStringRef inEnabledKey, + CFStringRef inHostKey, CFStringRef inPortKey, + CFStringRef *outProxyHost, int *ioProxyPort) { /* See if the proxy is enabled. */ CFNumberRef cf_enabled = CFDictionaryGetValue(inDict, inEnabledKey); if (cf_enabled == NULL) { From 406e1b42a92e555ce91fa672b8b4c2f26babd7c0 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 30 Jun 2016 22:10:08 +0000 Subject: [PATCH 102/125] Added tag jdk-9+125 for changeset 1f71a5d2b20b --- .hgtags-top-repo | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags-top-repo b/.hgtags-top-repo index 36b6337e14d..27eb593b749 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -367,3 +367,4 @@ cae471d3b87783e0a3deea658e1e1c84b2485b6c jdk-9+121 346be2df0f5b31d423807f53a719d1b9a67f3354 jdk-9+122 405d811c0d7b9b48ff718ae6c240b732f098c028 jdk-9+123 f80c841ae2545eaf9acd2724bccc305d98cefbe2 jdk-9+124 +9aa7d40f3a453f51e47f4c1b19eff5740a74a9f8 jdk-9+125 From 857fa7fe0a4e4c68c6db623b060d41c2eba188d6 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 30 Jun 2016 22:10:08 +0000 Subject: [PATCH 103/125] Added tag jdk-9+125 for changeset 70cd0a0846bf --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index f81930c6c03..91141129553 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -527,3 +527,4 @@ b64432bae5271735fd53300b2005b713e98ef411 jdk-9+114 af6b4ad908e732d23021f12e8322b204433d5cf6 jdk-9+122 75f81e1fecfb444f34f357295fe06af60e2762d9 jdk-9+123 479631362b4930be985245ea063d87d821a472eb jdk-9+124 +bb640b49741af3f57f9994129934c46fc173219f jdk-9+125 From 006c13eb51e3fc7f1b41ebea42bda805cc8f029c Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 30 Jun 2016 22:10:08 +0000 Subject: [PATCH 104/125] Added tag jdk-9+125 for changeset 8db725087c47 --- corba/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/corba/.hgtags b/corba/.hgtags index 216d97144ce..81364a38dbc 100644 --- a/corba/.hgtags +++ b/corba/.hgtags @@ -367,3 +367,4 @@ daf533920b1266603b5cbdab31908d2a931c5361 jdk-9+119 a39131aafc51a6fd8836e6ebe1b04458702ce7d6 jdk-9+122 e33a34cc551907617d8129c4faaf1a5a7e61d21c jdk-9+123 45121d5afb9d5bfadab75378572ad96832e0809e jdk-9+124 +1d48e67d1b91eb9f72e49e69a4021edb85e357fc jdk-9+125 From 1a29c4663106e4fc883b079b9182bc6c4d0ef058 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 30 Jun 2016 22:10:10 +0000 Subject: [PATCH 105/125] Added tag jdk-9+125 for changeset bba1e4c5c547 --- jdk/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/.hgtags b/jdk/.hgtags index 60cab9fc7e1..0068e0865f6 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -367,3 +367,4 @@ ee29aaab5889555ea56e4c0ed690aabb7613529d jdk-9+121 981ae344923f09c46d8d1d5a3ed9fa71deafe0c6 jdk-9+122 c40c8739bcdc88892ff58ebee3fd8a3f287be94d jdk-9+123 7ff61c55b5c6c124592f09b18953222009a204a6 jdk-9+124 +073ab1d4edf5590cf1af7b6d819350c14e425c1a jdk-9+125 From 4463ceae5940e4d1fd92dcffd6f2b2daf064ffc5 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 30 Jun 2016 22:10:11 +0000 Subject: [PATCH 106/125] Added tag jdk-9+125 for changeset e02c166da4dd --- nashorn/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/nashorn/.hgtags b/nashorn/.hgtags index 56db3f67644..f7b3d05812c 100644 --- a/nashorn/.hgtags +++ b/nashorn/.hgtags @@ -358,3 +358,4 @@ ba21793a0e4816283cc0ecdab5142a4959363529 jdk-9+114 b1de131a3fed6845c78bdda358ee127532f16a3f jdk-9+122 9ed859b4faaf9ff7cd35f9e7f51c7e630303067a jdk-9+123 5d68f5155dded7efec7d5aca5d631caa7ee1042b jdk-9+124 +a32d419d73fe881a935b567c57dab9bfe3ed5f92 jdk-9+125 From 5ded57cbddfa061a121f9932024c507547d92bca Mon Sep 17 00:00:00 2001 From: Amy Lu Date: Fri, 1 Jul 2016 12:50:58 +0800 Subject: [PATCH 107/125] 8160658: sun/security/tools/keytool/standard.sh fails on all platforms after JDK-8160415 Reviewed-by: weijun --- jdk/test/sun/security/tools/keytool/standard.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/test/sun/security/tools/keytool/standard.sh b/jdk/test/sun/security/tools/keytool/standard.sh index 2fb801ebd83..3c3d86718e7 100644 --- a/jdk/test/sun/security/tools/keytool/standard.sh +++ b/jdk/test/sun/security/tools/keytool/standard.sh @@ -26,7 +26,7 @@ # @author Weijun Wang # @run shell/timeout=600 standard.sh # @key intermittent -# + # This test is always excecuted. # # set a few environment variables so that the shell-script can run stand-alone From 2fc575a0957225d7ab7607ec775e624af71281ef Mon Sep 17 00:00:00 2001 From: Christoph Langer Date: Fri, 1 Jul 2016 11:29:55 +0200 Subject: [PATCH 108/125] 8160565: AIX port: cleanup of libo4 wrapper stub Reviewed-by: goetz, simonis --- hotspot/src/os/aix/vm/libo4.cpp | 52 ++++++++--- hotspot/src/os/aix/vm/libo4.hpp | 63 +++++++------ hotspot/src/os/aix/vm/libperfstat_aix.cpp | 8 +- hotspot/src/os/aix/vm/libperfstat_aix.hpp | 105 +++++++++++++++++++++- 4 files changed, 187 insertions(+), 41 deletions(-) diff --git a/hotspot/src/os/aix/vm/libo4.cpp b/hotspot/src/os/aix/vm/libo4.cpp index c0c8299aedd..9f114780a72 100644 --- a/hotspot/src/os/aix/vm/libo4.cpp +++ b/hotspot/src/os/aix/vm/libo4.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 SAP SE. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,17 +22,49 @@ * */ -// This is only a stub. Will flesh out later when/if we add further support -// for PASE. - #include "libo4.hpp" -bool libo4::init() { return false; } -void libo4::cleanup() {} -bool libo4::get_memory_info (unsigned long long* p_virt_total, unsigned long long* p_real_total, - unsigned long long* p_real_free, unsigned long long* p_pgsp_total, unsigned long long* p_pgsp_free) { +// global variables + +// whether initialization worked +static bool g_initialized = false; + +////////////////////////// +// class libo4 - impl // +////////////////////////// + +bool libo4::init() { + if (g_initialized) { + return true; + } return false; } -bool libo4::get_load_avg (double* p_avg1, double* p_avg5, double* p_avg15) { return false; } -bool libo4::realpath (const char* file_name, char* resolved_name, int resolved_name_len) { return false; } +void libo4::cleanup() { + if (g_initialized) { + g_initialized = false; + } +} + +bool libo4::get_memory_info(unsigned long long* p_virt_total, + unsigned long long* p_real_total, + unsigned long long* p_real_free, + unsigned long long* p_pgsp_total, + unsigned long long* p_pgsp_free) { + return false; +} + +bool libo4::get_load_avg(double* p_avg1, double* p_avg5, double* p_avg15) { + return false; +} + +bool libo4::realpath(const char* file_name, char* resolved_name, + int resolved_name_len) { + return false; +} + +bool libo4::removeEscapeMessageFromJoblogByContext(const void* context) { + // Note: no tracing here! We run in signal handling context + + return false; +} diff --git a/hotspot/src/os/aix/vm/libo4.hpp b/hotspot/src/os/aix/vm/libo4.hpp index fb920071dfc..6f9134f84e9 100644 --- a/hotspot/src/os/aix/vm/libo4.hpp +++ b/hotspot/src/os/aix/vm/libo4.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 SAP SE. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,56 +22,69 @@ * */ -// A C++ wrapper around the libo4 porting library. The libo4 porting library -// is a set of bridge functions into native AS/400 functionality. +// Class libo4 is a C++ wrapper around the libo4 porting library. It handles +// basic stuff like dynamic loading, library initialization etc. +// The libo4 porting library is a set of functions that bridge from the AIX +// runtime environment on OS/400 (aka PASE layer) into native OS/400 +// functionality (aka ILE layer) to close some functional gaps that exist in +// the PASE layer. #ifndef OS_AIX_VM_LIBO4_HPP #define OS_AIX_VM_LIBO4_HPP - class libo4 { public: - // Initialize the libo4 porting library. // Returns true if succeeded, false if error. static bool init(); - // cleanup of the libo4 porting library. + // Triggers cleanup of the libo4 porting library. static void cleanup(); - // returns a number of memory statistics from the - // AS/400. + // Returns a number of memory statistics from OS/400. + // + // See libo4.h for details on this API. // // Specify NULL for numbers you are not interested in. // - // returns false if an error happened. Activate OsMisc trace for + // Returns false if an error happened. Activate OsMisc trace for // trace output. // - static bool get_memory_info (unsigned long long* p_virt_total, unsigned long long* p_real_total, - unsigned long long* p_real_free, unsigned long long* p_pgsp_total, unsigned long long* p_pgsp_free); + static bool get_memory_info(unsigned long long* p_virt_total, + unsigned long long* p_real_total, + unsigned long long* p_real_free, + unsigned long long* p_pgsp_total, + unsigned long long* p_pgsp_free); - // returns information about system load + // Returns information about system load // (similar to "loadavg()" under other Unices) // - // Specify NULL for numbers you are not interested in. - // - // returns false if an error happened. Activate OsMisc trace for - // trace output. - // - static bool get_load_avg (double* p_avg1, double* p_avg5, double* p_avg15); - - // this is a replacement for the "realpath()" API which does not really work - // on PASE + // See libo4.h for details on this API. // // Specify NULL for numbers you are not interested in. // - // returns false if an error happened. Activate OsMisc trace for + // Returns false if an error happened. Activate OsMisc trace for // trace output. // - static bool realpath (const char* file_name, - char* resolved_name, int resolved_name_len); + static bool get_load_avg(double* p_avg1, double* p_avg5, double* p_avg15); + // This is a replacement for the "realpath()" API which does not really work + // in PASE together with the (case insensitive but case preserving) + // filesystem on OS/400. + // + // See libo4.h for details on this API. + // + // Returns false if an error happened. Activate OsMisc trace for + // trace output. + // + static bool realpath(const char* file_name, char* resolved_name, + int resolved_name_len); + + // Call libo4_RemoveEscapeMessageFromJoblogByContext API to remove messages + // from the OS/400 job log. + // + // See libo4.h for details on this API. + static bool removeEscapeMessageFromJoblogByContext(const void* context); }; #endif // OS_AIX_VM_LIBO4_HPP - diff --git a/hotspot/src/os/aix/vm/libperfstat_aix.cpp b/hotspot/src/os/aix/vm/libperfstat_aix.cpp index 388b4052c9e..cffe6f41b91 100644 --- a/hotspot/src/os/aix/vm/libperfstat_aix.cpp +++ b/hotspot/src/os/aix/vm/libperfstat_aix.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 SAP SE. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -180,10 +180,12 @@ bool libperfstat::get_cpuinfo(cpuinfo_t* pci) { memset (&psct, '\0', sizeof(psct)); if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(PERFSTAT_CPU_TOTAL_T_LATEST), 1)) { - if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(perfstat_cpu_total_t_61), 1)) { - if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(perfstat_cpu_total_t_53), 1)) { + if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(perfstat_cpu_total_t_71), 1)) { + if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(perfstat_cpu_total_t_61), 1)) { + if (-1 == libperfstat::perfstat_cpu_total(NULL, &psct, sizeof(perfstat_cpu_total_t_53), 1)) { trcVerbose("perfstat_cpu_total() failed (errno=%d)", errno); return false; + } } } } diff --git a/hotspot/src/os/aix/vm/libperfstat_aix.hpp b/hotspot/src/os/aix/vm/libperfstat_aix.hpp index 164f486a2dc..bf01abf5a5d 100644 --- a/hotspot/src/os/aix/vm/libperfstat_aix.hpp +++ b/hotspot/src/os/aix/vm/libperfstat_aix.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2013 SAP SE. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -337,10 +337,109 @@ typedef struct { /* global cpu information AIX 7.1 */ int spurrflag; /* set if running in spurr mode */ u_longlong_t version; /* version number (1, 2, etc.,) */ /* >>>>> END OF STRUCTURE DEFINITION <<<<< */ -#define CURR_VERSION_CPU_TOTAL 1 /* Incremented by one for every new release * +/* #define CURR_VERSION_CPU_TOTAL 1 Incremented by one for every new release * * of perfstat_cpu_total_t data structure */ } perfstat_cpu_total_t_71; +typedef struct { /* global cpu information AIX 7.2 / 6.1 TL6 (see oslevel -r) */ + int ncpus; /* number of active logical processors */ + int ncpus_cfg; /* number of configured processors */ + char description[IDENTIFIER_LENGTH]; /* processor description (type/official name) */ + u_longlong_t processorHZ; /* processor speed in Hz */ + u_longlong_t user; /* raw total number of clock ticks spent in user mode */ + u_longlong_t sys; /* raw total number of clock ticks spent in system mode */ + u_longlong_t idle; /* raw total number of clock ticks spent idle */ + u_longlong_t wait; /* raw total number of clock ticks spent waiting for I/O */ + u_longlong_t pswitch; /* number of process switches (change in currently running process) */ + u_longlong_t syscall; /* number of system calls executed */ + u_longlong_t sysread; /* number of read system calls executed */ + u_longlong_t syswrite; /* number of write system calls executed */ + u_longlong_t sysfork; /* number of forks system calls executed */ + u_longlong_t sysexec; /* number of execs system calls executed */ + u_longlong_t readch; /* number of characters tranferred with read system call */ + u_longlong_t writech; /* number of characters tranferred with write system call */ + u_longlong_t devintrs; /* number of device interrupts */ + u_longlong_t softintrs; /* number of software interrupts */ + time_t lbolt; /* number of ticks since last reboot */ + u_longlong_t loadavg[3]; /* (1<. */ + u_longlong_t runque; /* length of the run queue (processes ready) */ + u_longlong_t swpque; /* ength of the swap queue (processes waiting to be paged in) */ + u_longlong_t bread; /* number of blocks read */ + u_longlong_t bwrite; /* number of blocks written */ + u_longlong_t lread; /* number of logical read requests */ + u_longlong_t lwrite; /* number of logical write requests */ + u_longlong_t phread; /* number of physical reads (reads on raw devices) */ + u_longlong_t phwrite; /* number of physical writes (writes on raw devices) */ + u_longlong_t runocc; /* updated whenever runque is updated, i.e. the runqueue is occupied. + * This can be used to compute the simple average of ready processes */ + u_longlong_t swpocc; /* updated whenever swpque is updated. i.e. the swpqueue is occupied. + * This can be used to compute the simple average processes waiting to be paged in */ + u_longlong_t iget; /* number of inode lookups */ + u_longlong_t namei; /* number of vnode lookup from a path name */ + u_longlong_t dirblk; /* number of 512-byte block reads by the directory search routine to locate an entry for a file */ + u_longlong_t msg; /* number of IPC message operations */ + u_longlong_t sema; /* number of IPC semaphore operations */ + u_longlong_t rcvint; /* number of tty receive interrupts */ + u_longlong_t xmtint; /* number of tyy transmit interrupts */ + u_longlong_t mdmint; /* number of modem interrupts */ + u_longlong_t tty_rawinch; /* number of raw input characters */ + u_longlong_t tty_caninch; /* number of canonical input characters (always zero) */ + u_longlong_t tty_rawoutch;/* number of raw output characters */ + u_longlong_t ksched; /* number of kernel processes created */ + u_longlong_t koverf; /* kernel process creation attempts where: + * -the user has forked to their maximum limit + * -the configuration limit of processes has been reached */ + u_longlong_t kexit; /* number of kernel processes that became zombies */ + u_longlong_t rbread; /* number of remote read requests */ + u_longlong_t rcread; /* number of cached remote reads */ + u_longlong_t rbwrt; /* number of remote writes */ + u_longlong_t rcwrt; /* number of cached remote writes */ + u_longlong_t traps; /* number of traps */ + int ncpus_high; /* index of highest processor online */ + u_longlong_t puser; /* raw number of physical processor tics in user mode */ + u_longlong_t psys; /* raw number of physical processor tics in system mode */ + u_longlong_t pidle; /* raw number of physical processor tics idle */ + u_longlong_t pwait; /* raw number of physical processor tics waiting for I/O */ + u_longlong_t decrintrs; /* number of decrementer tics interrupts */ + u_longlong_t mpcrintrs; /* number of mpc's received interrupts */ + u_longlong_t mpcsintrs; /* number of mpc's sent interrupts */ + u_longlong_t phantintrs; /* number of phantom interrupts */ + u_longlong_t idle_donated_purr; /* number of idle cycles donated by a dedicated partition enabled for donation */ + u_longlong_t idle_donated_spurr;/* number of idle spurr cycles donated by a dedicated partition enabled for donation */ + u_longlong_t busy_donated_purr; /* number of busy cycles donated by a dedicated partition enabled for donation */ + u_longlong_t busy_donated_spurr;/* number of busy spurr cycles donated by a dedicated partition enabled for donation */ + u_longlong_t idle_stolen_purr; /* number of idle cycles stolen by the hypervisor from a dedicated partition */ + u_longlong_t idle_stolen_spurr; /* number of idle spurr cycles stolen by the hypervisor from a dedicated partition */ + u_longlong_t busy_stolen_purr; /* number of busy cycles stolen by the hypervisor from a dedicated partition */ + u_longlong_t busy_stolen_spurr; /* number of busy spurr cycles stolen by the hypervisor from a dedicated partition */ + short iowait; /* number of processes that are asleep waiting for buffered I/O */ + short physio; /* number of processes waiting for raw I/O */ + longlong_t twait; /* number of threads that are waiting for filesystem direct(cio) */ + u_longlong_t hpi; /* number of hypervisor page-ins */ + u_longlong_t hpit; /* Time spent in hypervisor page-ins (in nanoseconds) */ + u_longlong_t puser_spurr; /* number of spurr cycles spent in user mode */ + u_longlong_t psys_spurr; /* number of spurr cycles spent in kernel mode */ + u_longlong_t pidle_spurr; /* number of spurr cycles spent in idle mode */ + u_longlong_t pwait_spurr; /* number of spurr cycles spent in wait mode */ + int spurrflag; /* set if running in spurr mode */ + u_longlong_t version; /* version number (1, 2, etc.,) */ + u_longlong_t tb_last; /*time base counter */ + u_longlong_t purr_coalescing; /* If the calling partition is + * authorized to see pool wide statistics then + * PURR cycles consumed to coalesce data + * else set to zero.*/ + u_longlong_t spurr_coalescing; /* If the calling partition is + * authorized to see pool wide statistics then + * SPURR cycles consumed to coalesce data + * else set to zero.*/ + +/* >>>>> END OF STRUCTURE DEFINITION <<<<< */ +#define CURR_VERSION_CPU_TOTAL 2 /* Incremented by one for every new release * + * of perfstat_cpu_total_t data structure */ +} perfstat_cpu_total_t_72; + + typedef union { uint w; struct { @@ -756,7 +855,7 @@ typedef struct { /* WPAR identifier */ ////////////////////////////////////////////////////////////////////////////////////////////////////////////// #define PERFSTAT_PARTITON_TOTAL_T_LATEST perfstat_partition_total_t_71_1/* latest perfstat_partition_total_t structure */ -#define PERFSTAT_CPU_TOTAL_T_LATEST perfstat_cpu_total_t_71 /* latest perfstat_cpu_total_t structure */ +#define PERFSTAT_CPU_TOTAL_T_LATEST perfstat_cpu_total_t_72 /* latest perfstat_cpu_total_t structure */ #define PERFSTAT_WPAR_TOTAL_T_LATEST perfstat_wpar_total_t_71 /* latest perfstat_wpar_total_t structure */ class libperfstat { From 7076b38523d007792c5257148508dcd6bd6aadbb Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Fri, 1 Jul 2016 17:03:59 +0200 Subject: [PATCH 109/125] 8160722: Module summary generation fails on Windows 32bit Reviewed-by: tbell --- common/autoconf/spec.gmk.in | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/common/autoconf/spec.gmk.in b/common/autoconf/spec.gmk.in index 706d5edcc59..8ddc28f53aa 100644 --- a/common/autoconf/spec.gmk.in +++ b/common/autoconf/spec.gmk.in @@ -578,7 +578,7 @@ SJAVAC_SERVER_JAVA=@FIXPATH@ @FIXPATH_DETACH_FLAG@ $(SJAVAC_SERVER_JAVA_CMD) \ JAVAC_FLAGS?=@JAVAC_FLAGS@ -BUILD_JAVA_FLAGS:=-Xms64M -Xmx1100M +BUILD_JAVA_FLAGS := @BOOTCYCLE_JVM_ARGS_BIG@ BUILD_JAVA=@FIXPATH@ $(BUILD_JDK)/bin/java $(BUILD_JAVA_FLAGS) # Use ?= as this can be overridden from bootcycle-spec.gmk From 0ce484cdd700be234679b98807a0aa394f070df3 Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Fri, 1 Jul 2016 11:42:26 -0400 Subject: [PATCH 110/125] 8157707: Deprecate the java.security.Certificate API with forRemoval=true Reviewed-by: xuelei --- .../java.base/share/classes/java/security/Certificate.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/security/Certificate.java b/jdk/src/java.base/share/classes/java/security/Certificate.java index 489c6d620af..4fe278aa431 100644 --- a/jdk/src/java.base/share/classes/java/security/Certificate.java +++ b/jdk/src/java.base/share/classes/java/security/Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -60,9 +60,10 @@ import java.util.Date; * This Certificate interface is entirely deprecated and * is here to allow for a smooth transition to the new * package. + * This class is subject to removal in a future version of Java SE. * @see java.security.cert.Certificate */ -@Deprecated +@Deprecated(since="1.2", forRemoval=true) public interface Certificate { /** From 5a7acbc027f92744f77eff5cbd3770c8d9b8af58 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Fri, 1 Jul 2016 18:29:24 +0200 Subject: [PATCH 111/125] 8160728: Update compare script to clean baseline Reviewed-by: tbell --- common/bin/compare.sh | 39 ++++++++++++++++++++++++++++++++++----- 1 file changed, 34 insertions(+), 5 deletions(-) diff --git a/common/bin/compare.sh b/common/bin/compare.sh index c1663fd8e4c..a54f1d4197c 100644 --- a/common/bin/compare.sh +++ b/common/bin/compare.sh @@ -102,10 +102,13 @@ diff_text() { # Ignore date strings in class files. # Anonymous lambda classes get randomly assigned counters in their names. if test "x$SUFFIX" = "xclass"; then - if [ "$NAME" = "module-info.class" ] || [ "$NAME" = "SystemModules.class" ] - then - # The SystemModules.class and module-info.class have several issues - # with random ordering of elements in HashSets. + if [ "$NAME" = "SystemModules.class" ]; then + # The SystemModules.class is not comparable. The way it is generated is + # too random. It can even be of different size for no apparent reason. + TMP="" + elif [ "$NAME" = "module-info.class" ]; then + # The module-info.class have several issues with random ordering of + # elements in HashSets. MODULES_CLASS_FILTER="$SED \ -e 's/,$//' \ -e 's/;$//' \ @@ -369,6 +372,14 @@ compare_general_files() { $CAT $OTHER_DIR/$f | eval "$HTML_FILTER" > $OTHER_FILE & $CAT $THIS_DIR/$f | eval "$HTML_FILTER" > $THIS_FILE & wait + elif [ "$f" = "./lib/classlist" ]; then + # The classlist files may have some lines in random order + OTHER_FILE=$WORK_DIR/$f.other + THIS_FILE=$WORK_DIR/$f.this + $MKDIR -p $(dirname $OTHER_FILE) $(dirname $THIS_FILE) + $RM $OTHER_FILE $THIS_FILE + $CAT $OTHER_DIR/$f | $SORT > $OTHER_FILE + $CAT $THIS_DIR/$f | $SORT > $THIS_FILE else OTHER_FILE=$OTHER_DIR/$f THIS_FILE=$THIS_DIR/$f @@ -651,7 +662,7 @@ compare_bin_file() { OTHER_DIZ_FILE=${OTHER_FILE_BASE}.diz else # Some files, jli.dll, appears twice in the image but only one of - # thme has a diz file next to it. + # them has a diz file next to it. OTHER_DIZ_FILE="$($FIND $OTHER_DIR -name $DIZ_NAME | $SED 1q)" if [ ! -f "$OTHER_DIZ_FILE" ]; then # As a last resort, look for diz file in the whole build output @@ -1335,6 +1346,24 @@ if [ "$SKIP_DEFAULT" != "true" ]; then OTHER_JDK="$OTHER/images/jdk" OTHER_JRE="$OTHER/images/jre" echo "Selecting jdk images for compare" + elif [ -d "$(ls -d $THIS/licensee-src/build/*/images/jdk)" ] \ + && [ -d "$(ls -d $OTHER/licensee-src/build/*/images/jdk)" ] + then + echo "Selecting licensee images for compare" + # Simply override the THIS and OTHER dir with the build dir from + # the nested licensee source build for the rest of the script + # execution. + OLD_THIS="$THIS" + OLD_OTHER="$OTHER" + THIS="$(ls -d $THIS/licensee-src/build/*)" + OTHER="$(ls -d $OTHER/licensee-src/build/*)" + THIS_JDK="$THIS/images/jdk" + THIS_JRE="$THIS/images/jre" + OTHER_JDK="$OTHER/images/jdk" + OTHER_JRE="$OTHER/images/jre" + # Rewrite the path to tools that are used from the build + JIMAGE="$(echo "$JIMAGE" | $SED "s|$OLD_THIS|$THIS|g")" + JAVAP="$(echo "$JAVAP" | $SED "s|$OLD_THIS|$THIS|g")" else echo "No common images found." exit 1 From 3520eff6115544cbe65950a724b84e4f67014fd3 Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Fri, 1 Jul 2016 14:29:18 -0400 Subject: [PATCH 112/125] 8157847: Deprecate the java.security.acl API with forRemoval=true Reviewed-by: weijun, mchung --- jdk/src/java.base/share/classes/java/security/acl/Acl.java | 5 +++-- .../java.base/share/classes/java/security/acl/AclEntry.java | 5 +++-- .../classes/java/security/acl/AclNotFoundException.java | 5 +++-- jdk/src/java.base/share/classes/java/security/acl/Group.java | 5 +++-- .../share/classes/java/security/acl/LastOwnerException.java | 5 +++-- .../share/classes/java/security/acl/NotOwnerException.java | 5 +++-- jdk/src/java.base/share/classes/java/security/acl/Owner.java | 5 +++-- .../share/classes/java/security/acl/Permission.java | 5 +++-- .../share/classes/java/security/acl/package-info.java | 5 +++-- 9 files changed, 27 insertions(+), 18 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/security/acl/Acl.java b/jdk/src/java.base/share/classes/java/security/acl/Acl.java index 9131966a08e..1a00125879c 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/Acl.java +++ b/jdk/src/java.base/share/classes/java/security/acl/Acl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -85,9 +85,10 @@ import java.security.Principal; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public interface Acl extends Owner { /** diff --git a/jdk/src/java.base/share/classes/java/security/acl/AclEntry.java b/jdk/src/java.base/share/classes/java/security/acl/AclEntry.java index dd4e548ab47..212b7341784 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/AclEntry.java +++ b/jdk/src/java.base/share/classes/java/security/acl/AclEntry.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -53,8 +53,9 @@ import java.security.Principal; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public interface AclEntry extends Cloneable { /** diff --git a/jdk/src/java.base/share/classes/java/security/acl/AclNotFoundException.java b/jdk/src/java.base/share/classes/java/security/acl/AclNotFoundException.java index 0a153e25665..c1bf55a3aa8 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/AclNotFoundException.java +++ b/jdk/src/java.base/share/classes/java/security/acl/AclNotFoundException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,8 +33,9 @@ package java.security.acl; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class AclNotFoundException extends Exception { private static final long serialVersionUID = 5684295034092681791L; diff --git a/jdk/src/java.base/share/classes/java/security/acl/Group.java b/jdk/src/java.base/share/classes/java/security/acl/Group.java index 9ff69f563cb..50bf2dd4e38 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/Group.java +++ b/jdk/src/java.base/share/classes/java/security/acl/Group.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -42,8 +42,9 @@ import java.security.Principal; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public interface Group extends Principal { /** diff --git a/jdk/src/java.base/share/classes/java/security/acl/LastOwnerException.java b/jdk/src/java.base/share/classes/java/security/acl/LastOwnerException.java index b25bf84d46c..bae12d06795 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/LastOwnerException.java +++ b/jdk/src/java.base/share/classes/java/security/acl/LastOwnerException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -35,8 +35,9 @@ package java.security.acl; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class LastOwnerException extends Exception { private static final long serialVersionUID = -5141997548211140359L; diff --git a/jdk/src/java.base/share/classes/java/security/acl/NotOwnerException.java b/jdk/src/java.base/share/classes/java/security/acl/NotOwnerException.java index 68d214d7185..74519606bf6 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/NotOwnerException.java +++ b/jdk/src/java.base/share/classes/java/security/acl/NotOwnerException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,8 +34,9 @@ package java.security.acl; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class NotOwnerException extends Exception { private static final long serialVersionUID = -5555597911163362399L; diff --git a/jdk/src/java.base/share/classes/java/security/acl/Owner.java b/jdk/src/java.base/share/classes/java/security/acl/Owner.java index 2a4999b277d..8f88a1150a9 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/Owner.java +++ b/jdk/src/java.base/share/classes/java/security/acl/Owner.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,8 +38,9 @@ import java.security.Principal; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public interface Owner { /** diff --git a/jdk/src/java.base/share/classes/java/security/acl/Permission.java b/jdk/src/java.base/share/classes/java/security/acl/Permission.java index 236f10795f0..bcccf167cce 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/Permission.java +++ b/jdk/src/java.base/share/classes/java/security/acl/Permission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,8 +34,9 @@ package java.security.acl; * * @deprecated This package has been replaced by {@code java.security.Policy} * and related classes since 1.2. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public interface Permission { /** diff --git a/jdk/src/java.base/share/classes/java/security/acl/package-info.java b/jdk/src/java.base/share/classes/java/security/acl/package-info.java index 9f2186fbb2e..fdbb6dcd268 100644 --- a/jdk/src/java.base/share/classes/java/security/acl/package-info.java +++ b/jdk/src/java.base/share/classes/java/security/acl/package-info.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,8 @@ * The classes and interfaces in this package have been deprecated. New * classes should not be added to this package. The {@code java.security} * package contains suitable replacements. See {@link java.security.Policy} - * and related classes for details. + * and related classes for details. This package is subject to removal in a + * future version of Java SE. * * @since 1.1 */ From 70e069ea5d2bf85e3ee1f67276a359f97d75de89 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Fri, 1 Jul 2016 12:54:18 -0700 Subject: [PATCH 113/125] 8160687: (fs) Cannot tell which WatchService test is not deleting temp directories "work*" Change name of "work" temp directory to "TestName" Reviewed-by: rriggs --- jdk/test/java/nio/file/WatchService/DeleteInterference.java | 2 +- jdk/test/java/nio/file/WatchService/LotsOfCancels.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/test/java/nio/file/WatchService/DeleteInterference.java b/jdk/test/java/nio/file/WatchService/DeleteInterference.java index 6a11271a546..347912c434c 100644 --- a/jdk/test/java/nio/file/WatchService/DeleteInterference.java +++ b/jdk/test/java/nio/file/WatchService/DeleteInterference.java @@ -49,7 +49,7 @@ public class DeleteInterference { * directory. */ public static void main(String[] args) throws Exception { - Path dir = Files.createTempDirectory("work"); + Path dir = Files.createTempDirectory("DeleteInterference"); ExecutorService pool = Executors.newCachedThreadPool(); try { Future task1 = pool.submit(() -> openAndCloseWatcher(dir)); diff --git a/jdk/test/java/nio/file/WatchService/LotsOfCancels.java b/jdk/test/java/nio/file/WatchService/LotsOfCancels.java index cb7f9eff9af..e4abc308d67 100644 --- a/jdk/test/java/nio/file/WatchService/LotsOfCancels.java +++ b/jdk/test/java/nio/file/WatchService/LotsOfCancels.java @@ -50,7 +50,7 @@ public class LotsOfCancels { // one to bash on cancel, the other to poll the events ExecutorService pool = Executors.newCachedThreadPool(); try { - Path top = Files.createTempDirectory("work"); + Path top = Files.createTempDirectory("LotsOfCancels"); top.toFile().deleteOnExit(); for (int i=1; i<=16; i++) { Path dir = Files.createDirectory(top.resolve("dir-" + i)); From 7f9465ef1569450a05b7438f5b7be82527ab5bbd Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Fri, 1 Jul 2016 12:55:23 -0700 Subject: [PATCH 114/125] 8160018: (fs) Remove GioFileTypeDetector on Solaris Remove the GioFileTypeDetector from the chain of FileTypeDetectors provided by SolarisFileSystemProvider. Reviewed-by: rriggs --- jdk/make/lib/NioLibraries.gmk | 5 +---- jdk/make/mapfiles/libnio/mapfile-solaris | 2 -- .../classes/sun/nio/fs/GioFileTypeDetector.java | 0 .../{unix => linux}/native/libnio/fs/GioFileTypeDetector.c | 0 .../classes/sun/nio/fs/SolarisFileSystemProvider.java | 5 ++--- 5 files changed, 3 insertions(+), 9 deletions(-) rename jdk/src/java.base/{unix => linux}/classes/sun/nio/fs/GioFileTypeDetector.java (100%) rename jdk/src/java.base/{unix => linux}/native/libnio/fs/GioFileTypeDetector.c (100%) diff --git a/jdk/make/lib/NioLibraries.gmk b/jdk/make/lib/NioLibraries.gmk index 203447c513f..053763506f9 100644 --- a/jdk/make/lib/NioLibraries.gmk +++ b/jdk/make/lib/NioLibraries.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -46,9 +46,6 @@ endif ifeq ($(OPENJDK_TARGET_OS), macosx) BUILD_LIBNIO_MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libnio/mapfile-$(OPENJDK_TARGET_OS) - BUILD_LIBNIO_EXFILES += \ - GioFileTypeDetector.c \ - # endif ifeq ($(OPENJDK_TARGET_OS), solaris) diff --git a/jdk/make/mapfiles/libnio/mapfile-solaris b/jdk/make/mapfiles/libnio/mapfile-solaris index a38701ab3b5..d7a9da908ca 100644 --- a/jdk/make/mapfiles/libnio/mapfile-solaris +++ b/jdk/make/mapfiles/libnio/mapfile-solaris @@ -131,8 +131,6 @@ SUNWprivate_1.1 { Java_sun_nio_ch_SolarisEventPort_port_1get; Java_sun_nio_ch_SolarisEventPort_port_1getn; Java_sun_nio_ch_SolarisEventPort_port_1send; - Java_sun_nio_fs_GioFileTypeDetector_initializeGio; - Java_sun_nio_fs_GioFileTypeDetector_probeGio; Java_sun_nio_fs_UnixNativeDispatcher_init; Java_sun_nio_fs_UnixNativeDispatcher_getcwd; Java_sun_nio_fs_UnixNativeDispatcher_strerror; diff --git a/jdk/src/java.base/unix/classes/sun/nio/fs/GioFileTypeDetector.java b/jdk/src/java.base/linux/classes/sun/nio/fs/GioFileTypeDetector.java similarity index 100% rename from jdk/src/java.base/unix/classes/sun/nio/fs/GioFileTypeDetector.java rename to jdk/src/java.base/linux/classes/sun/nio/fs/GioFileTypeDetector.java diff --git a/jdk/src/java.base/unix/native/libnio/fs/GioFileTypeDetector.c b/jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c similarity index 100% rename from jdk/src/java.base/unix/native/libnio/fs/GioFileTypeDetector.c rename to jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c diff --git a/jdk/src/java.base/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java b/jdk/src/java.base/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java index c50b4a8b7f0..bef7decb1c9 100644 --- a/jdk/src/java.base/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java +++ b/jdk/src/java.base/solaris/classes/sun/nio/fs/SolarisFileSystemProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -88,8 +88,7 @@ public class SolarisFileSystemProvider extends UnixFileSystemProvider { GetPropertyAction.privilegedGetProperty("user.home"), ".mime.types"); Path etcMimeTypes = Paths.get("/etc/mime.types"); - return chain(new GioFileTypeDetector(), - new MimeTypesFileTypeDetector(userMimeTypes), + return chain(new MimeTypesFileTypeDetector(userMimeTypes), new MimeTypesFileTypeDetector(etcMimeTypes)); } } From d5efeccf785bfa3b98ca54fefc62af5c458e9463 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Fri, 1 Jul 2016 12:57:12 -0700 Subject: [PATCH 115/125] 8160018: (fs) Remove GioFileTypeDetector on Solaris Remove the GioFileTypeDetector from the chain of FileTypeDetectors provided by SolarisFileSystemProvider. Reviewed-by: rriggs --- make/CompileJavaModules.gmk | 4 ---- 1 file changed, 4 deletions(-) diff --git a/make/CompileJavaModules.gmk b/make/CompileJavaModules.gmk index 55c91f1dc61..ed603cd8717 100644 --- a/make/CompileJavaModules.gmk +++ b/make/CompileJavaModules.gmk @@ -55,10 +55,6 @@ java.base_EXCLUDES += java/lang/doc-files # data files and shouldn't go in the product java.base_EXCLUDE_FILES += sun/text/resources/BreakIteratorRules.java -ifeq ($(OPENJDK_TARGET_OS), macosx) - java.base_EXCLUDE_FILES += sun/nio/fs/GnomeFileTypeDetector.java -endif - ifneq ($(filter solaris macosx linux windows,$(OPENJDK_TARGET_OS)), ) java.base_EXCLUDE_FILES += \ sun/nio/ch/AbstractPollSelectorImpl.java \ From dc536f2d7454cd9bb9bdcff013480b400aa33a83 Mon Sep 17 00:00:00 2001 From: Vinnie Ryan Date: Fri, 1 Jul 2016 22:55:26 +0100 Subject: [PATCH 116/125] 8157730: Mark deprecated java.security.{Identity,IdentityScope,Signer} APIs with forRemoval=true Reviewed-by: mullan --- .../share/classes/java/security/Identity.java | 11 ++++++----- .../share/classes/java/security/IdentityScope.java | 14 +++++++++----- .../share/classes/java/security/Signer.java | 11 ++++++----- 3 files changed, 21 insertions(+), 15 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/security/Identity.java b/jdk/src/java.base/share/classes/java/security/Identity.java index 83e10cee128..44713c4906f 100644 --- a/jdk/src/java.base/share/classes/java/security/Identity.java +++ b/jdk/src/java.base/share/classes/java/security/Identity.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,11 +52,12 @@ import java.util.*; * * @author Benjamin Renaud * @deprecated This class is no longer used. Its functionality has been - * replaced by {@code java.security.KeyStore}, the - * {@code java.security.cert} package, and - * {@code java.security.Principal}. + * replaced by {@link java.security.KeyStore}, the + * {@link java.security.cert} package, and + * {@link java.security.Principal}. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="1.2", forRemoval=true) public abstract class Identity implements Principal, Serializable { /** use serialVersionUID from JDK 1.1.x for interoperability */ diff --git a/jdk/src/java.base/share/classes/java/security/IdentityScope.java b/jdk/src/java.base/share/classes/java/security/IdentityScope.java index 763f8308c53..e07d724438a 100644 --- a/jdk/src/java.base/share/classes/java/security/IdentityScope.java +++ b/jdk/src/java.base/share/classes/java/security/IdentityScope.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -57,11 +57,15 @@ import java.util.Properties; * @author Benjamin Renaud * * @deprecated This class is no longer used. Its functionality has been - * replaced by {@code java.security.KeyStore}, the - * {@code java.security.cert} package, and - * {@code java.security.Principal}. + * replaced by {@link java.security.KeyStore}, the + * {@link java.security.cert} package, and + * {@link java.security.Principal}. + * This class is subject to removal in a future version of Java SE. + * + * Note that the security property {@code policy.ignoreIdentityScope} + * is only applicable to these APIs and is also a candidate for removal. */ -@Deprecated +@Deprecated(since="1.2", forRemoval=true) public abstract class IdentityScope extends Identity { diff --git a/jdk/src/java.base/share/classes/java/security/Signer.java b/jdk/src/java.base/share/classes/java/security/Signer.java index 2edf668b530..93c6ff73af5 100644 --- a/jdk/src/java.base/share/classes/java/security/Signer.java +++ b/jdk/src/java.base/share/classes/java/security/Signer.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -40,11 +40,12 @@ import java.io.*; * @author Benjamin Renaud * * @deprecated This class is no longer used. Its functionality has been - * replaced by {@code java.security.KeyStore}, the - * {@code java.security.cert} package, and - * {@code java.security.Principal}. + * replaced by {@link java.security.KeyStore}, the + * {@link java.security.cert} package, and + * {@link java.security.Principal}. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="1.2", forRemoval=true) public abstract class Signer extends Identity { private static final long serialVersionUID = -1763464102261361480L; From 3596fa197cfc66c2b1f2083da50fc5c814656aea Mon Sep 17 00:00:00 2001 From: Kumar Srinivasan Date: Fri, 1 Jul 2016 15:13:00 -0700 Subject: [PATCH 117/125] 8145418: [macosx] Help message for -Xdock:name has a superfluous trailing quote " Reviewed-by: naoto --- .../share/classes/sun/launcher/resources/launcher.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties index 83b328d7de8..73cfc8af252 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher.properties @@ -141,7 +141,7 @@ java.launcher.X.macosx.usage=\ The following options are Mac OS X specific:\n\ \ -XstartOnFirstThread\n\ \ run the main() method on the first (AppKit) thread\n\ -\ -Xdock:name="\n\ +\ -Xdock:name=\n\ \ override default application name displayed in dock\n\ \ -Xdock:icon=\n\ \ override default icon displayed in dock\n\n From 50e42d221205d7a3361b2eec7075b11aa387b4fb Mon Sep 17 00:00:00 2001 From: Anthony Scarpino Date: Sat, 2 Jul 2016 13:51:20 -0700 Subject: [PATCH 118/125] 8159180: Remove default setting for jdk.security.provider.preferred Reviewed-by: xuelei --- .../share/conf/security/java.security | 10 +------ .../jca/PreferredProviderNegativeTest.java | 29 ++++++++++--------- .../security/jca/PreferredProviderTest.java | 10 +++++-- 3 files changed, 24 insertions(+), 25 deletions(-) diff --git a/jdk/src/java.base/share/conf/security/java.security b/jdk/src/java.base/share/conf/security/java.security index 942a303b58d..269a8cb0198 100644 --- a/jdk/src/java.base/share/conf/security/java.security +++ b/jdk/src/java.base/share/conf/security/java.security @@ -116,15 +116,7 @@ security.provider.tbd=SunPKCS11 # Example: # jdk.security.provider.preferred=AES/GCM/NoPadding:SunJCE, \ # MessageDigest.SHA-256:SUN, Group.HmacSHA2:SunJCE -#ifdef solaris-sparc -jdk.security.provider.preferred=AES:SunJCE, SHA1:SUN, Group.SHA2:SUN, \ - HmacSHA1:SunJCE, Group.HmacSHA2:SunJCE -#endif -#ifdef solaris-x86 -jdk.security.provider.preferred=AES:SunJCE, SHA1:SUN, Group.SHA2:SUN, \ - HmacSHA1:SunJCE, Group.HmacSHA2:SunJCE, RSA:SunRsaSign, \ - SHA1withRSA:SunRsaSign, Group.SHA2RSA:SunRsaSign -#endif +#jdk.security.provider.preferred= # diff --git a/jdk/test/sun/security/jca/PreferredProviderNegativeTest.java b/jdk/test/sun/security/jca/PreferredProviderNegativeTest.java index c6f5cf28c87..aee69101622 100644 --- a/jdk/test/sun/security/jca/PreferredProviderNegativeTest.java +++ b/jdk/test/sun/security/jca/PreferredProviderNegativeTest.java @@ -62,7 +62,7 @@ public class PreferredProviderNegativeTest { } } else { if (!cipher.getProvider().getName().equals(arrays[1])) { - throw new RuntimeException("Test Faild:The provider could be " + throw new RuntimeException("Test Failed:The provider could be " + "set by valid provider."); } } @@ -73,13 +73,13 @@ public class PreferredProviderNegativeTest { * Test that the setting of the security property after Cipher.getInstance() * does not influence previously loaded instances */ - public static void afterJCESet(String value) + public static void afterJCESet(String value, String expected) throws NoSuchAlgorithmException, NoSuchPaddingException { String[] arrays = value.split(":"); Cipher cipher = Cipher.getInstance(arrays[0]); Security.setProperty(SEC_PREF_PROP, value); - if (!cipher.getProvider().getName().equals("SunJCE")) { + if (!cipher.getProvider().getName().equals(expected)) { throw new RuntimeException("Test Failed:The security property can't" + " be updated after JCE load."); } @@ -105,25 +105,28 @@ public class PreferredProviderNegativeTest { public static void main(String[] args) throws NoSuchAlgorithmException, NoSuchPaddingException { + String expected; + String value = args[1]; + // If OS is solaris, expect OracleUcrypto, otherwise SunJCE + if (System.getProperty("os.name").toLowerCase().contains("sun")) { + expected = "OracleUcrypto"; + } else { + expected = "SunJCE"; + } + if (args.length >= 2) { switch (args[0]) { case "preSet": boolean negativeProvider = Boolean.valueOf(args[2]); - boolean solaris = System.getProperty("os.name") - .toLowerCase().contains("sun"); - String value = args[1]; - if (args[1].split(":").length < 2) { - if (solaris) { - value += ":OracleUcrypto"; - } else { - value += ":SunJCE"; - } + if (!args[1].contains(":")) { + value += ":" + expected; } PreferredProviderNegativeTest.preJCESet( value, negativeProvider); break; case "afterSet": - PreferredProviderNegativeTest.afterJCESet(args[1]); + PreferredProviderNegativeTest.afterJCESet(args[1], + expected); break; case "invalidAlg": PreferredProviderNegativeTest.invalidAlg(args[1]); diff --git a/jdk/test/sun/security/jca/PreferredProviderTest.java b/jdk/test/sun/security/jca/PreferredProviderTest.java index 72026222fee..1e130997342 100644 --- a/jdk/test/sun/security/jca/PreferredProviderTest.java +++ b/jdk/test/sun/security/jca/PreferredProviderTest.java @@ -38,6 +38,7 @@ import javax.crypto.NoSuchPaddingException; * @bug 8076359 8133151 8145344 8150512 8155847 * @summary Test the value for new jdk.security.provider.preferred * security property + * @run main/othervm PreferredProviderTest */ public class PreferredProviderTest { @@ -59,12 +60,14 @@ public class PreferredProviderTest { verifyDigestProvider(os, type, Arrays.asList( new DataTuple("SHA-256", "SUN"))); } else { - //For solaris the preferred algorithm/provider is already set in - //java.security file which will be verified. + //Solaris has different providers that support the same algorithm + //which makes for better testing. switch (type) { case "sparcv9": preferredProp = "AES:SunJCE, SHA1:SUN, Group.SHA2:SUN, " + "HmacSHA1:SunJCE, Group.HmacSHA2:SunJCE"; + Security.setProperty( + "jdk.security.provider.preferred", preferredProp); verifyPreferredProviderProperty(os, type, preferredProp); verifyDigestProvider(os, type, Arrays.asList( @@ -89,7 +92,8 @@ public class PreferredProviderTest { "HmacSHA1:SunJCE, Group.HmacSHA2:SunJCE, " + "RSA:SunRsaSign, SHA1withRSA:SunRsaSign, " + "Group.SHA2RSA:SunRsaSign"; - + Security.setProperty( + "jdk.security.provider.preferred", preferredProp); verifyPreferredProviderProperty(os, type, preferredProp); verifyKeyFactoryProvider(os, type, Arrays.asList( From 06075b3f8b7348aa4d0ee6c5f378669f7e18fdca Mon Sep 17 00:00:00 2001 From: Ivan Gerasimov Date: Sun, 3 Jul 2016 05:30:47 +0300 Subject: [PATCH 119/125] 8159822: Non-synchronized access to shared members of com.sun.jndi.ldap.pool.Pool Reviewed-by: coffeys --- .../classes/com/sun/jndi/ldap/pool/Pool.java | 26 ++++++++++++------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/jdk/src/java.naming/share/classes/com/sun/jndi/ldap/pool/Pool.java b/jdk/src/java.naming/share/classes/com/sun/jndi/ldap/pool/Pool.java index 723f11a8783..a2813bf9233 100644 --- a/jdk/src/java.naming/share/classes/com/sun/jndi/ldap/pool/Pool.java +++ b/jdk/src/java.naming/share/classes/com/sun/jndi/ldap/pool/Pool.java @@ -118,7 +118,11 @@ final public class Pool { PooledConnectionFactory factory) throws NamingException { d("get(): ", id); - d("size: ", map.size()); + if (debug) { + synchronized (map) { + d("size: ", map.size()); + } + } expungeStaleConnections(); @@ -141,10 +145,9 @@ final public class Pool { // Keep the weak reference through the element of a linked list weakRefs.add(weakRef); } + d("get(): size after: ", map.size()); } - d("get(): size after: ", map.size()); - return conns.get(timeout, factory); // get one connection from list } @@ -209,19 +212,24 @@ final public class Pool { out.println("maximum pool size: " + maxSize); out.println("preferred pool size: " + prefSize); out.println("initial pool size: " + initSize); - out.println("current pool size: " + map.size()); - for (Map.Entry entry : map.entrySet()) { - id = entry.getKey(); - conns = entry.getValue().getConnections(); - out.println(" " + id + ":" + conns.getStats()); + synchronized (map) { + out.println("current pool size: " + map.size()); + + for (Map.Entry entry : map.entrySet()) { + id = entry.getKey(); + conns = entry.getValue().getConnections(); + out.println(" " + id + ":" + conns.getStats()); + } } out.println("====== Pool end ====================="); } public String toString() { - return super.toString() + " " + map.toString(); + synchronized (map) { + return super.toString() + " " + map.toString(); + } } private void d(String msg, int i) { From 99921c2f0ee40803a3e03ff7bcf1345c4516eeb6 Mon Sep 17 00:00:00 2001 From: Masayoshi Okutsu Date: Mon, 4 Jul 2016 13:00:15 +0900 Subject: [PATCH 120/125] 8159943: JavaTimeSupplementary resource bundles need update Reviewed-by: naoto --- .../text/resources/JavaTimeSupplementary.java | 392 +++++---------- .../resources/JavaTimeSupplementary_en.java | 217 +++------ .../sun/util/resources/LocaleData.java | 17 +- .../ext/JavaTimeSupplementary_ar.java | 458 ++++++----------- .../ext/JavaTimeSupplementary_ar_JO.java | 54 +- .../ext/JavaTimeSupplementary_ar_LB.java | 54 +- .../ext/JavaTimeSupplementary_ar_SY.java | 54 +- .../ext/JavaTimeSupplementary_be.java | 294 ++++------- .../ext/JavaTimeSupplementary_bg.java | 292 ++++------- .../ext/JavaTimeSupplementary_ca.java | 270 ++++------ .../ext/JavaTimeSupplementary_cs.java | 352 ++++--------- .../ext/JavaTimeSupplementary_da.java | 340 ++++--------- .../ext/JavaTimeSupplementary_de.java | 348 ++++--------- .../ext/JavaTimeSupplementary_de_AT.java | 4 +- .../ext/JavaTimeSupplementary_el.java | 324 +++++------- .../ext/JavaTimeSupplementary_en_AU.java | 181 +++---- .../ext/JavaTimeSupplementary_en_CA.java | 66 +-- .../ext/JavaTimeSupplementary_en_GB.java | 90 ++-- .../ext/JavaTimeSupplementary_en_IE.java | 94 ++-- .../ext/JavaTimeSupplementary_en_IN.java | 58 +-- .../ext/JavaTimeSupplementary_en_MT.java | 79 ++- .../ext/JavaTimeSupplementary_en_NZ.java | 58 +-- .../ext/JavaTimeSupplementary_en_SG.java | 58 +-- .../ext/JavaTimeSupplementary_en_ZA.java | 66 +-- .../ext/JavaTimeSupplementary_es.java | 343 ++++--------- .../ext/JavaTimeSupplementary_es_AR.java | 180 +++++++ .../ext/JavaTimeSupplementary_es_BO.java | 182 +++++++ .../ext/JavaTimeSupplementary_es_CL.java | 142 ++++-- .../ext/JavaTimeSupplementary_es_CO.java | 131 ++--- .../ext/JavaTimeSupplementary_es_CR.java | 182 +++++++ .../ext/JavaTimeSupplementary_es_DO.java | 167 ++++--- .../ext/JavaTimeSupplementary_es_EC.java | 182 +++++++ .../ext/JavaTimeSupplementary_es_GT.java | 132 +++-- .../ext/JavaTimeSupplementary_es_HN.java | 132 +++-- .../ext/JavaTimeSupplementary_es_MX.java | 228 +++++---- .../ext/JavaTimeSupplementary_es_PA.java | 175 ++++--- .../ext/JavaTimeSupplementary_es_PE.java | 121 +++-- .../ext/JavaTimeSupplementary_es_PR.java | 136 ++++-- .../ext/JavaTimeSupplementary_es_PY.java | 163 +++++++ .../ext/JavaTimeSupplementary_es_US.java | 136 ++++-- .../ext/JavaTimeSupplementary_es_UY.java | 91 +++- .../ext/JavaTimeSupplementary_es_VE.java | 132 +++-- .../ext/JavaTimeSupplementary_et.java | 264 ++++------ .../ext/JavaTimeSupplementary_fi.java | 377 +++++--------- .../ext/JavaTimeSupplementary_fr.java | 333 ++++--------- .../ext/JavaTimeSupplementary_fr_BE.java | 58 +-- .../ext/JavaTimeSupplementary_fr_CA.java | 40 +- .../ext/JavaTimeSupplementary_fr_CH.java | 58 +-- .../ext/JavaTimeSupplementary_ga.java | 290 ++++------- .../ext/JavaTimeSupplementary_hi_IN.java | 302 ++++-------- .../ext/JavaTimeSupplementary_hr.java | 339 ++++--------- .../ext/JavaTimeSupplementary_hu.java | 372 +++++--------- .../ext/JavaTimeSupplementary_in.java | 365 +++++--------- .../ext/JavaTimeSupplementary_is.java | 290 ++++------- .../ext/JavaTimeSupplementary_it.java | 337 ++++--------- .../ext/JavaTimeSupplementary_it_CH.java | 62 +-- .../ext/JavaTimeSupplementary_iw.java | 294 ++++------- .../ext/JavaTimeSupplementary_ja.java | 461 ++++++------------ .../ext/JavaTimeSupplementary_ko.java | 416 +++++----------- .../ext/JavaTimeSupplementary_lt.java | 349 ++++--------- .../ext/JavaTimeSupplementary_lv.java | 313 ++++-------- .../ext/JavaTimeSupplementary_mk.java | 290 ++++------- .../ext/JavaTimeSupplementary_ms.java | 327 ++++--------- .../ext/JavaTimeSupplementary_mt.java | 234 +++------ .../ext/JavaTimeSupplementary_nl.java | 349 ++++--------- .../ext/JavaTimeSupplementary_nl_BE.java | 66 +-- .../ext/JavaTimeSupplementary_no.java | 371 +++++--------- .../ext/JavaTimeSupplementary_pl.java | 309 ++++-------- .../ext/JavaTimeSupplementary_pt.java | 326 ++++--------- .../ext/JavaTimeSupplementary_pt_PT.java | 171 +++---- .../ext/JavaTimeSupplementary_ro.java | 309 ++++-------- .../ext/JavaTimeSupplementary_ru.java | 367 +++++--------- .../ext/JavaTimeSupplementary_sk.java | 272 ++++------- .../ext/JavaTimeSupplementary_sl.java | 290 ++++------- .../ext/JavaTimeSupplementary_sq.java | 292 ++++------- .../ext/JavaTimeSupplementary_sr.java | 387 +++++---------- .../ext/JavaTimeSupplementary_sr_BA.java | 89 ++++ .../ext/JavaTimeSupplementary_sr_Latn.java | 262 ++++------ .../ext/JavaTimeSupplementary_sv.java | 358 +++++--------- .../ext/JavaTimeSupplementary_th.java | 356 +++++--------- .../ext/JavaTimeSupplementary_tr.java | 419 ++++++---------- .../ext/JavaTimeSupplementary_uk.java | 285 ++++------- .../ext/JavaTimeSupplementary_vi.java | 326 ++++--------- .../ext/JavaTimeSupplementary_zh.java | 359 +++++--------- .../ext/JavaTimeSupplementary_zh_HK.java | 123 +++++ .../ext/JavaTimeSupplementary_zh_SG.java | 104 ++++ .../ext/JavaTimeSupplementary_zh_TW.java | 275 ++++------- .../resources/JavaTimeSupplementaryTest.java | 153 ++++++ 88 files changed, 7922 insertions(+), 12042 deletions(-) create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_AR.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_BO.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CR.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_EC.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PY.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_BA.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_HK.java create mode 100644 jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_SG.java create mode 100644 jdk/test/sun/text/resources/JavaTimeSupplementaryTest.java diff --git a/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary.java b/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary.java index 7d62fa52030..2a7de9bde43 100644 --- a/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary.java +++ b/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary.java @@ -72,7 +72,53 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] rocMonthNarrows = { + final String[] sharedQuarterNames = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedQuarterNarrows = { + "1", + "2", + "3", + "4", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "G y-MM-dd", + }; + + final String[] sharedDayNames = { + "Sun", + "Mon", + "Tue", + "Wed", + "Thu", + "Fri", + "Sat", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "T", + "W", + "T", + "F", + "S", + }; + + final String[] sharedEras = { + "", + "AH", + }; + + final String[] sharedMonthNarrows = { "1", "2", "3", @@ -87,31 +133,62 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { "12", "", }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "GGGGG y-MM-dd", + }; + + final String[] sharedJavaTimeLongEras = { + "", + "Meiji", + "Taisho", + "Showa", + "Heisei", + }; + + final String[] sharedShortEras = { + "Before R.O.C.", + "R.O.C.", + }; + + final String[] sharedMonthNames = { + "Jan", + "Feb", + "Mar", + "Apr", + "May", + "Jun", + "Jul", + "Aug", + "Sep", + "Oct", + "Nov", + "Dec", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNarrows }, { "field.dayperiod", "Dayperiod" }, { "field.era", @@ -133,52 +210,15 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { { "field.zone", "Zone" }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Sun", - "Mon", - "Tue", - "Wed", - "Thu", - "Fri", - "Sat", - } - }, + sharedDayNames }, { "islamic.DayNames", - new String[] { - "Sun", - "Mon", - "Tue", - "Wed", - "Thu", - "Fri", - "Sat", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "T", - "W", - "T", - "F", - "S", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", new String[] { "Muh.", @@ -214,63 +254,23 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { } }, { "islamic.MonthNarrows", - rocMonthNarrows }, + sharedMonthNarrows }, { "islamic.QuarterNames", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNarrows }, { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", new String[] { "BC", @@ -284,13 +284,7 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "G y MMMM d (EEEE)", @@ -300,23 +294,9 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "", - "Meiji", - "Taisho", - "Showa", - "Heisei", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.short.Eras", - new String[] { - "", - "Meiji", - "Taisho", - "Showa", - "Heisei", - } - }, + sharedJavaTimeLongEras }, { "java.time.long.Eras", new String[] { "BCE", @@ -324,13 +304,7 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "BC", @@ -338,137 +312,37 @@ public class JavaTimeSupplementary extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "roc.DayNames", - new String[] { - "Sun", - "Mon", - "Tue", - "Wed", - "Thu", - "Fri", - "Sat", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "T", - "W", - "T", - "F", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "R.O.C.", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", - new String[] { - "Jan", - "Feb", - "Mar", - "Apr", - "May", - "Jun", - "Jul", - "Aug", - "Sep", - "Oct", - "Nov", - "Dec", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "Jan", - "Feb", - "Mar", - "Apr", - "May", - "Jun", - "Jul", - "Aug", - "Sep", - "Oct", - "Nov", - "Dec", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", - rocMonthNarrows }, + sharedMonthNarrows }, { "roc.QuarterNames", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNarrows }, { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "R.O.C.", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "R.O.C.", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "R.O.C.", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary_en.java b/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary_en.java index 9ba3f94304b..bd4c6cedbac 100644 --- a/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary_en.java +++ b/jdk/src/java.base/share/classes/sun/text/resources/JavaTimeSupplementary_en.java @@ -72,15 +72,64 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1st quarter", + "2nd quarter", + "3rd quarter", + "4th quarter", + }; + + final String[] sharedDatePatterns = { + "EEEE, MMMM d, y GGGG", + "MMMM d, y GGGG", + "MMM d, y GGGG", + "M/d/y G", + }; + + final String[] sharedDayNames = { + "Sunday", + "Monday", + "Tuesday", + "Wednesday", + "Thursday", + "Friday", + "Saturday", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, MMMM d, y G", + "MMMM d, y G", + "MMM d, y G", + "M/d/y GGGGG", + }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "1st quarter", - "2nd quarter", - "3rd quarter", - "4th quarter", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Buddhist Calendar" }, { "calendarname.gregorian", @@ -124,62 +173,19 @@ public class JavaTimeSupplementary_en extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE, MMMM d, y GGGG", - "MMMM d, y GGGG", - "MMM d, y GGGG", - "M/d/y G", - } - }, + sharedDatePatterns }, { "islamic.DayNames", - new String[] { - "Sunday", - "Monday", - "Tuesday", - "Wednesday", - "Thursday", - "Friday", - "Saturday", - } - }, + sharedDayNames }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1st quarter", - "2nd quarter", - "3rd quarter", - "4th quarter", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "M/d/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -187,21 +193,9 @@ public class JavaTimeSupplementary_en extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "M/d/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "M/d/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "Before Christ", @@ -209,21 +203,9 @@ public class JavaTimeSupplementary_en extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "M/d/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE, MMMM d, y GGGG", - "MMMM d, y GGGG", - "MMM d, y GGGG", - "M/d/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", new String[] { "Sun", @@ -236,22 +218,9 @@ public class JavaTimeSupplementary_en extends OpenListResourceBundle { } }, { "roc.DayNames", - new String[] { - "Sunday", - "Monday", - "Tuesday", - "Wednesday", - "Thursday", - "Friday", - "Saturday", - } - }, + sharedDayNames }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthNames", new String[] { "January", @@ -287,53 +256,19 @@ public class JavaTimeSupplementary_en extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1st quarter", - "2nd quarter", - "3rd quarter", - "4th quarter", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/java.base/share/classes/sun/util/resources/LocaleData.java b/jdk/src/java.base/share/classes/sun/util/resources/LocaleData.java index b98973ad918..5510b6cc250 100644 --- a/jdk/src/java.base/share/classes/sun/util/resources/LocaleData.java +++ b/jdk/src/java.base/share/classes/sun/util/resources/LocaleData.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -228,6 +228,9 @@ public class LocaleData { private static class LocaleDataStrategy implements Bundles.Strategy { private static final LocaleDataStrategy INSTANCE = new LocaleDataStrategy(); + // TODO: avoid hard-coded Locales + private static Set JAVA_BASE_LOCALES + = Set.of(Locale.ROOT, Locale.ENGLISH, Locale.US, new Locale("en", "US", "POSIX")); private LocaleDataStrategy() { } @@ -275,11 +278,7 @@ public class LocaleData { } boolean inJavaBaseModule(String baseName, Locale locale) { - // TODO: avoid hard-coded Locales - return locale.equals(Locale.ROOT) || - (locale.getLanguage() == "en" && - (locale.getCountry().isEmpty() || - locale.getCountry() == "US")); + return JAVA_BASE_LOCALES.contains(locale); } @Override @@ -313,6 +312,9 @@ public class LocaleData { private static class SupplementaryStrategy extends LocaleDataStrategy { private static final SupplementaryStrategy INSTANCE = new SupplementaryStrategy(); + // TODO: avoid hard-coded Locales + private static Set JAVA_BASE_LOCALES + = Set.of(Locale.ROOT, Locale.ENGLISH, Locale.US); private SupplementaryStrategy() { } @@ -332,8 +334,7 @@ public class LocaleData { @Override boolean inJavaBaseModule(String baseName, Locale locale) { - // TODO: avoid hard-coded Locales - return locale.equals(Locale.ROOT) || locale.getLanguage() == "en"; + return JAVA_BASE_LOCALES.contains(locale); } } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java index 7d2382b0f37..93df2b4f089 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java @@ -72,35 +72,121 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ar extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimebuddhistlongEras = { + final String[] sharedQuarterNames = { + "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", + "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", + "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", + }; + + final String[] sharedQuarterNarrows = { + "\u0661", + "\u0662", + "\u0663", + "\u0664", + }; + + final String[] sharedAmPmMarkers = { + "\u0635", + "\u0645", + }; + + final String[] sharedDayNames = { + "\u0627\u0644\u0623\u062d\u062f", + "\u0627\u0644\u0627\u062b\u0646\u064a\u0646", + "\u0627\u0644\u062b\u0644\u0627\u062b\u0627\u0621", + "\u0627\u0644\u0623\u0631\u0628\u0639\u0627\u0621", + "\u0627\u0644\u062e\u0645\u064a\u0633", + "\u0627\u0644\u062c\u0645\u0639\u0629", + "\u0627\u0644\u0633\u0628\u062a", + }; + + final String[] sharedDayNarrows = { + "\u062d", + "\u0646", + "\u062b", + "\u0631", + "\u062e", + "\u062c", + "\u0633", + }; + + final String[] sharedEras = { + "", + "\u0647\u0640", + }; + + final String[] sharedMonthNames = { + "\u0645\u062d\u0631\u0645", + "\u0635\u0641\u0631", + "\u0631\u0628\u064a\u0639 \u0627\u0644\u0623\u0648\u0644", + "\u0631\u0628\u064a\u0639 \u0627\u0644\u0622\u062e\u0631", + "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0623\u0648\u0644\u0649", + "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0622\u062e\u0631\u0629", + "\u0631\u062c\u0628", + "\u0634\u0639\u0628\u0627\u0646", + "\u0631\u0645\u0636\u0627\u0646", + "\u0634\u0648\u0627\u0644", + "\u0630\u0648 \u0627\u0644\u0642\u0639\u062f\u0629", + "\u0630\u0648 \u0627\u0644\u062d\u062c\u0629", + "", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE\u060c d MMMM\u060c y G", + "d MMMM\u060c y G", + "dd\u200f/MM\u200f/y G", + "d\u200f/M\u200f/y GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { "BC", "\u0627\u0644\u062a\u0642\u0648\u064a\u0645 \u0627\u0644\u0628\u0648\u0630\u064a", }; + + final String[] sharedJavaTimeShortEras = { + "\u0645", + "\u0645\u064a\u062c\u064a", + "\u062a\u064a\u0634\u0648", + "\u0634\u0648\u0648\u0627", + "\u0647\u064a\u0633\u064a", + }; + + final String[] sharedShortEras = { + "Before R.O.C.", + "\u062c\u0645\u0647\u0648\u0631\u064a\u0629 \u0627\u0644\u0635\u064a", + }; + + final String[] sharedMonthAbbreviations = { + "\u064a\u0646\u0627\u064a\u0631", + "\u0641\u0628\u0631\u0627\u064a\u0631", + "\u0645\u0627\u0631\u0633", + "\u0623\u0628\u0631\u064a\u0644", + "\u0645\u0627\u064a\u0648", + "\u064a\u0648\u0646\u064a\u0648", + "\u064a\u0648\u0644\u064a\u0648", + "\u0623\u063a\u0633\u0637\u0633", + "\u0633\u0628\u062a\u0645\u0628\u0631", + "\u0623\u0643\u062a\u0648\u0628\u0631", + "\u0646\u0648\u0641\u0645\u0628\u0631", + "\u062f\u064a\u0633\u0645\u0628\u0631", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "\u0661", - "\u0662", - "\u0663", - "\u0664", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "\u0627\u0644\u062a\u0642\u0648\u064a\u0645 \u0627\u0644\u0628\u0648\u0630\u064a" }, { "calendarname.gregorian", @@ -138,11 +224,7 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { { "field.zone", "\u0627\u0644\u062a\u0648\u0642\u064a\u062a" }, { "islamic.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE\u060c d MMMM\u060c y GGGG", @@ -152,78 +234,17 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "\u0627\u0644\u0623\u062d\u062f", - "\u0627\u0644\u0627\u062b\u0646\u064a\u0646", - "\u0627\u0644\u062b\u0644\u0627\u062b\u0627\u0621", - "\u0627\u0644\u0623\u0631\u0628\u0639\u0627\u0621", - "\u0627\u0644\u062e\u0645\u064a\u0633", - "\u0627\u0644\u062c\u0645\u0639\u0629", - "\u0627\u0644\u0633\u0628\u062a", - } - }, + sharedDayNames }, { "islamic.DayNames", - new String[] { - "\u0627\u0644\u0623\u062d\u062f", - "\u0627\u0644\u0627\u062b\u0646\u064a\u0646", - "\u0627\u0644\u062b\u0644\u0627\u062b\u0627\u0621", - "\u0627\u0644\u0623\u0631\u0628\u0639\u0627\u0621", - "\u0627\u0644\u062e\u0645\u064a\u0633", - "\u0627\u0644\u062c\u0645\u0639\u0629", - "\u0627\u0644\u0633\u0628\u062a", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u062d", - "\u0646", - "\u062b", - "\u0631", - "\u062e", - "\u062c", - "\u0633", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "\u0647\u0640", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", - new String[] { - "\u0645\u062d\u0631\u0645", - "\u0635\u0641\u0631", - "\u0631\u0628\u064a\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0631\u0628\u064a\u0639 \u0627\u0644\u0622\u062e\u0631", - "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0623\u0648\u0644\u0649", - "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0622\u062e\u0631\u0629", - "\u0631\u062c\u0628", - "\u0634\u0639\u0628\u0627\u0646", - "\u0631\u0645\u0636\u0627\u0646", - "\u0634\u0648\u0627\u0644", - "\u0630\u0648 \u0627\u0644\u0642\u0639\u062f\u0629", - "\u0630\u0648 \u0627\u0644\u062d\u062c\u0629", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNames", - new String[] { - "\u0645\u062d\u0631\u0645", - "\u0635\u0641\u0631", - "\u0631\u0628\u064a\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0631\u0628\u064a\u0639 \u0627\u0644\u0622\u062e\u0631", - "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0623\u0648\u0644\u0649", - "\u062c\u0645\u0627\u062f\u0649 \u0627\u0644\u0622\u062e\u0631\u0629", - "\u0631\u062c\u0628", - "\u0634\u0639\u0628\u0627\u0646", - "\u0631\u0645\u0636\u0627\u0646", - "\u0634\u0648\u0627\u0644", - "\u0630\u0648 \u0627\u0644\u0642\u0639\u062f\u0629", - "\u0630\u0648 \u0627\u0644\u062d\u062c\u0629", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNarrows", new String[] { "\u0661", @@ -242,79 +263,29 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "islamic.QuarterNames", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "\u0661", - "\u0662", - "\u0663", - "\u0664", - } - }, + sharedQuarterNarrows }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "\u0647\u0640", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "\u0647\u0640", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u0647\u0640", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE\u060c d MMMM\u060c y G", - "d MMMM\u060c y G", - "dd\u200f/MM\u200f/y G", - "d\u200f/M\u200f/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", new String[] { "EEEE\u060c d MMMM\u060c y G", @@ -324,31 +295,11 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE\u060c d MMMM\u060c y G", - "d MMMM\u060c y G", - "dd\u200f/MM\u200f/y G", - "d\u200f/M\u200f/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", - new String[] { - "\u0645", - "\u0645\u064a\u062c\u064a", - "\u062a\u064a\u0634\u0648", - "\u0634\u0648\u0648\u0627", - "\u0647\u064a\u0633\u064a", - } - }, + sharedJavaTimeShortEras }, { "java.time.japanese.short.Eras", - new String[] { - "\u0645", - "\u0645\u064a\u062c\u064a", - "\u062a\u064a\u0634\u0648", - "\u0634\u0648\u0648\u0627", - "\u0647\u064a\u0633\u064a", - } - }, + sharedJavaTimeShortEras }, { "java.time.long.Eras", new String[] { "\u0642\u0628\u0644 \u0627\u0644\u0645\u064a\u0644\u0627\u062f", @@ -356,13 +307,7 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE\u060c d MMMM\u060c y G", - "d MMMM\u060c y G", - "dd\u200f/MM\u200f/y G", - "d\u200f/M\u200f/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u0642.\u0645", @@ -370,11 +315,7 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "EEEE\u060c d MMMM\u060c y GGGG", @@ -384,78 +325,17 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "\u0627\u0644\u0623\u062d\u062f", - "\u0627\u0644\u0627\u062b\u0646\u064a\u0646", - "\u0627\u0644\u062b\u0644\u0627\u062b\u0627\u0621", - "\u0627\u0644\u0623\u0631\u0628\u0639\u0627\u0621", - "\u0627\u0644\u062e\u0645\u064a\u0633", - "\u0627\u0644\u062c\u0645\u0639\u0629", - "\u0627\u0644\u0633\u0628\u062a", - } - }, + sharedDayNames }, { "roc.DayNames", - new String[] { - "\u0627\u0644\u0623\u062d\u062f", - "\u0627\u0644\u0627\u062b\u0646\u064a\u0646", - "\u0627\u0644\u062b\u0644\u0627\u062b\u0627\u0621", - "\u0627\u0644\u0623\u0631\u0628\u0639\u0627\u0621", - "\u0627\u0644\u062e\u0645\u064a\u0633", - "\u0627\u0644\u062c\u0645\u0639\u0629", - "\u0627\u0644\u0633\u0628\u062a", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u062d", - "\u0646", - "\u062b", - "\u0631", - "\u062e", - "\u062c", - "\u0633", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "\u062c\u0645\u0647\u0648\u0631\u064a\u0629 \u0627\u0644\u0635\u064a", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", - new String[] { - "\u064a\u0646\u0627\u064a\u0631", - "\u0641\u0628\u0631\u0627\u064a\u0631", - "\u0645\u0627\u0631\u0633", - "\u0623\u0628\u0631\u064a\u0644", - "\u0645\u0627\u064a\u0648", - "\u064a\u0648\u0646\u064a\u0648", - "\u064a\u0648\u0644\u064a\u0648", - "\u0623\u063a\u0633\u0637\u0633", - "\u0633\u0628\u062a\u0645\u0628\u0631", - "\u0623\u0643\u062a\u0648\u0628\u0631", - "\u0646\u0648\u0641\u0645\u0628\u0631", - "\u062f\u064a\u0633\u0645\u0628\u0631", - "", - } - }, + sharedMonthAbbreviations }, { "roc.MonthNames", - new String[] { - "\u064a\u0646\u0627\u064a\u0631", - "\u0641\u0628\u0631\u0627\u064a\u0631", - "\u0645\u0627\u0631\u0633", - "\u0623\u0628\u0631\u064a\u0644", - "\u0645\u0627\u064a\u0648", - "\u064a\u0648\u0646\u064a\u0648", - "\u064a\u0648\u0644\u064a\u0648", - "\u0623\u063a\u0633\u0637\u0633", - "\u0633\u0628\u062a\u0645\u0628\u0631", - "\u0623\u0643\u062a\u0648\u0628\u0631", - "\u0646\u0648\u0641\u0645\u0628\u0631", - "\u062f\u064a\u0633\u0645\u0628\u0631", - "", - } - }, + sharedMonthAbbreviations }, { "roc.MonthNarrows", new String[] { "\u064a", @@ -474,67 +354,23 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "roc.QuarterNames", - new String[] { - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0623\u0648\u0644", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u062b\u0627\u0644\u062b", - "\u0627\u0644\u0631\u0628\u0639 \u0627\u0644\u0631\u0627\u0628\u0639", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "\u0661", - "\u0662", - "\u0663", - "\u0664", - } - }, + sharedQuarterNarrows }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "\u062c\u0645\u0647\u0648\u0631\u064a\u0629 \u0627\u0644\u0635\u064a", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u0635", - "\u0645", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "\u062c\u0645\u0647\u0648\u0631\u064a\u0629 \u0627\u0644\u0635\u064a", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "\u062c\u0645\u0647\u0648\u0631\u064a\u0629 \u0627\u0644\u0635\u064a", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_JO.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_JO.java index 3dfd781e626..b1471d64718 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_JO.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_JO.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,41 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ar_JO extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedMonthNames = { + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0634\u0628\u0627\u0637", + "\u0622\u0630\u0627\u0631", + "\u0646\u064a\u0633\u0627\u0646", + "\u0623\u064a\u0627\u0631", + "\u062d\u0632\u064a\u0631\u0627\u0646", + "\u062a\u0645\u0648\u0632", + "\u0622\u0628", + "\u0623\u064a\u0644\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", + "", + }; + return new Object[][] { { "roc.MonthAbbreviations", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", new String[] { "\u0643", diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_LB.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_LB.java index c0795d1f641..e4b587240e6 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_LB.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_LB.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,41 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ar_LB extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedMonthNames = { + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0634\u0628\u0627\u0637", + "\u0622\u0630\u0627\u0631", + "\u0646\u064a\u0633\u0627\u0646", + "\u0623\u064a\u0627\u0631", + "\u062d\u0632\u064a\u0631\u0627\u0646", + "\u062a\u0645\u0648\u0632", + "\u0622\u0628", + "\u0623\u064a\u0644\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", + "", + }; + return new Object[][] { { "roc.MonthAbbreviations", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", new String[] { "\u0643", diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_SY.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_SY.java index 6edcfe4089b..0fcd7abfbdf 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_SY.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar_SY.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,41 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ar_SY extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedMonthNames = { + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0634\u0628\u0627\u0637", + "\u0622\u0630\u0627\u0631", + "\u0646\u064a\u0633\u0627\u0646", + "\u0623\u064a\u0627\u0631", + "\u062d\u0632\u064a\u0631\u0627\u0646", + "\u062a\u0645\u0648\u0632", + "\u0622\u0628", + "\u0623\u064a\u0644\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", + "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", + "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", + "", + }; + return new Object[][] { { "roc.MonthAbbreviations", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0634\u0628\u0627\u0637", - "\u0622\u0630\u0627\u0631", - "\u0646\u064a\u0633\u0627\u0646", - "\u0623\u064a\u0627\u0631", - "\u062d\u0632\u064a\u0631\u0627\u0646", - "\u062a\u0645\u0648\u0632", - "\u0622\u0628", - "\u0623\u064a\u0644\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u0623\u0648\u0644", - "\u062a\u0634\u0631\u064a\u0646 \u0627\u0644\u062b\u0627\u0646\u064a", - "\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u0623\u0648\u0644", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", new String[] { "\u0643", diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_be.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_be.java index 35890522c82..0ab0654ae06 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_be.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_be.java @@ -72,23 +72,91 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_be extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1-\u0448\u044b \u043a\u0432.", + "2-\u0433\u0456 \u043a\u0432.", + "3-\u0446\u0456 \u043a\u0432.", + "4-\u0442\u044b \u043a\u0432.", + }; + + final String[] sharedQuarterNames = { + "1-\u0448\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "2-\u0433\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "3-\u0446\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "4-\u0442\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + }; + + final String[] sharedAmPmMarkers = { + "\u0434\u0430 \u043f\u0430\u045e\u0434\u043d\u044f", + "\u043f\u0430\u0441\u043b\u044f \u043f\u0430\u045e\u0434\u043d\u044f", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d.M.y GGGG", + "d.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "\u043d\u0434", + "\u043f\u043d", + "\u0430\u045e", + "\u0441\u0440", + "\u0447\u0446", + "\u043f\u0442", + "\u0441\u0431", + }; + + final String[] sharedDayNames = { + "\u043d\u044f\u0434\u0437\u0435\u043b\u044f", + "\u043f\u0430\u043d\u044f\u0434\u0437\u0435\u043b\u0430\u043a", + "\u0430\u045e\u0442\u043e\u0440\u0430\u043a", + "\u0441\u0435\u0440\u0430\u0434\u0430", + "\u0447\u0430\u0446\u0432\u0435\u0440", + "\u043f\u044f\u0442\u043d\u0456\u0446\u0430", + "\u0441\u0443\u0431\u043e\u0442\u0430", + }; + + final String[] sharedDayNarrows = { + "\u043d", + "\u043f", + "\u0430", + "\u0441", + "\u0447", + "\u043f", + "\u0441", + }; + + final String[] sharedTimePatterns = { + "HH.mm.ss zzzz", + "HH.mm.ss z", + "HH.mm.ss", + "HH.mm", + }; + + final String[] sharedAbbreviatedAmPmMarkers = { + "\u0440\u0430\u043d\u0456\u0446\u044b", + "\u0432\u0435\u0447\u0430\u0440\u0430", + }; + + final String[] sharedNarrowAmPmMarkers = { + "\u0440\u0430\u043d.", + "\u0432\u0435\u0447.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d.M.y G", + "d.M.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1-\u0448\u044b \u043a\u0432.", - "2-\u0433\u0456 \u043a\u0432.", - "3-\u0446\u0456 \u043a\u0432.", - "4-\u0442\u044b \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1-\u0448\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0433\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0446\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0442\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0431\u0443\u0434\u044b\u0439\u0441\u043a\u0456 \u043a\u0430\u043b\u044f\u043d\u0434\u0430\u0440" }, { "calendarname.gregorian", @@ -124,96 +192,25 @@ public class JavaTimeSupplementary_be extends OpenListResourceBundle { { "field.zone", "\u0447\u0430\u0441\u0430\u0432\u044b \u043f\u043e\u044f\u0441" }, { "islamic.AmPmMarkers", - new String[] { - "\u0434\u0430 \u043f\u0430\u045e\u0434\u043d\u044f", - "\u043f\u0430\u0441\u043b\u044f \u043f\u0430\u045e\u0434\u043d\u044f", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u043d\u0434", - "\u043f\u043d", - "\u0430\u045e", - "\u0441\u0440", - "\u0447\u0446", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u043d\u044f\u0434\u0437\u0435\u043b\u044f", - "\u043f\u0430\u043d\u044f\u0434\u0437\u0435\u043b\u0430\u043a", - "\u0430\u045e\u0442\u043e\u0440\u0430\u043a", - "\u0441\u0435\u0440\u0430\u0434\u0430", - "\u0447\u0430\u0446\u0432\u0435\u0440", - "\u043f\u044f\u0442\u043d\u0456\u0446\u0430", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0430", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1-\u0448\u044b \u043a\u0432.", - "2-\u0433\u0456 \u043a\u0432.", - "3-\u0446\u0456 \u043a\u0432.", - "4-\u0442\u044b \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1-\u0448\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0433\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0446\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0442\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u0440\u0430\u043d\u0456\u0446\u044b", - "\u0432\u0435\u0447\u0430\u0440\u0430", - } - }, + sharedAbbreviatedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u0440\u0430\u043d.", - "\u0432\u0435\u0447.", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", new String[] { "EEEE, d MMMM y G", @@ -223,21 +220,9 @@ public class JavaTimeSupplementary_be extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u0434\u0430 \u043d\u0430\u0448\u0430\u0439 \u044d\u0440\u044b", @@ -245,13 +230,7 @@ public class JavaTimeSupplementary_be extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u0434\u0430 \u043d.\u0435.", @@ -259,52 +238,15 @@ public class JavaTimeSupplementary_be extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u0434\u0430 \u043f\u0430\u045e\u0434\u043d\u044f", - "\u043f\u0430\u0441\u043b\u044f \u043f\u0430\u045e\u0434\u043d\u044f", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u043d\u0434", - "\u043f\u043d", - "\u0430\u045e", - "\u0441\u0440", - "\u0447\u0446", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u043d\u044f\u0434\u0437\u0435\u043b\u044f", - "\u043f\u0430\u043d\u044f\u0434\u0437\u0435\u043b\u0430\u043a", - "\u0430\u045e\u0442\u043e\u0440\u0430\u043a", - "\u0441\u0435\u0440\u0430\u0434\u0430", - "\u0447\u0430\u0446\u0432\u0435\u0440", - "\u043f\u044f\u0442\u043d\u0456\u0446\u0430", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0430", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u0441\u0442\u0443", @@ -357,41 +299,15 @@ public class JavaTimeSupplementary_be extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1-\u0448\u044b \u043a\u0432.", - "2-\u0433\u0456 \u043a\u0432.", - "3-\u0446\u0456 \u043a\u0432.", - "4-\u0442\u044b \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1-\u0448\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0433\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0446\u0456 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0442\u044b \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u0440\u0430\u043d\u0456\u0446\u044b", - "\u0432\u0435\u0447\u0430\u0440\u0430", - } - }, + sharedAbbreviatedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u0440\u0430\u043d.", - "\u0432\u0435\u0447.", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_bg.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_bg.java index 6d6c53bb0ad..0d3c3d8f317 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_bg.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_bg.java @@ -72,23 +72,81 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_bg extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1. \u0442\u0440\u0438\u043c.", + "2. \u0442\u0440\u0438\u043c.", + "3. \u0442\u0440\u0438\u043c.", + "4. \u0442\u0440\u0438\u043c.", + }; + + final String[] sharedQuarterNames = { + "1. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", + "2. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", + "3. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", + "4. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", + }; + + final String[] sharedAmPmMarkers = { + "\u043f\u0440.\u043e\u0431.", + "\u0441\u043b.\u043e\u0431.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y '\u0433'. GGGG", + "d MMMM y '\u0433'. GGGG", + "d.MM.y '\u0433'. GGGG", + "d.MM.yy GGGG", + }; + + final String[] sharedDayAbbreviations = { + "\u043d\u0434", + "\u043f\u043d", + "\u0432\u0442", + "\u0441\u0440", + "\u0447\u0442", + "\u043f\u0442", + "\u0441\u0431", + }; + + final String[] sharedDayNames = { + "\u043d\u0435\u0434\u0435\u043b\u044f", + "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", + "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", + "\u0441\u0440\u044f\u0434\u0430", + "\u0447\u0435\u0442\u0432\u044a\u0440\u0442\u044a\u043a", + "\u043f\u0435\u0442\u044a\u043a", + "\u0441\u044a\u0431\u043e\u0442\u0430", + }; + + final String[] sharedDayNarrows = { + "\u043d", + "\u043f", + "\u0432", + "\u0441", + "\u0447", + "\u043f", + "\u0441", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y '\u0433'. G", + "d MMMM y '\u0433'. G", + "d.MM.y '\u0433'. G", + "d.MM.yy G", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1. \u0442\u0440\u0438\u043c.", - "2. \u0442\u0440\u0438\u043c.", - "3. \u0442\u0440\u0438\u043c.", - "4. \u0442\u0440\u0438\u043c.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "2. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "3. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "4. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0431\u0443\u0434\u0438\u0441\u0442\u043a\u0438 \u043a\u0430\u043b\u0435\u043d\u0434\u0430\u0440" }, { "calendarname.gregorian", @@ -124,52 +182,15 @@ public class JavaTimeSupplementary_bg extends OpenListResourceBundle { { "field.zone", "\u0447\u0430\u0441\u043e\u0432\u0430 \u0437\u043e\u043d\u0430" }, { "islamic.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. GGGG", - "d MMMM y '\u0433'. GGGG", - "d.MM.y '\u0433'. GGGG", - "d.MM.yy GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u043d\u0434", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u043b\u044f", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u044f\u0434\u0430", - "\u0447\u0435\u0442\u0432\u044a\u0440\u0442\u044a\u043a", - "\u043f\u0435\u0442\u044a\u043a", - "\u0441\u044a\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0432", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "\u043c\u0443\u0445\u0430\u0440\u0430\u043c", @@ -188,73 +209,21 @@ public class JavaTimeSupplementary_bg extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "1. \u0442\u0440\u0438\u043c.", - "2. \u0442\u0440\u0438\u043c.", - "3. \u0442\u0440\u0438\u043c.", - "4. \u0442\u0440\u0438\u043c.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "2. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "3. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "4. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d.MM.y '\u0433'. G", - "d.MM.yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d.MM.y '\u0433'. G", - "d.MM.yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d.MM.y '\u0433'. G", - "d.MM.yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u043f\u0440\u0435\u0434\u0438 \u0425\u0440\u0438\u0441\u0442\u0430", @@ -262,13 +231,7 @@ public class JavaTimeSupplementary_bg extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d.MM.y '\u0433'. G", - "d.MM.yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u043f\u0440.\u043d.\u0435.", @@ -276,52 +239,15 @@ public class JavaTimeSupplementary_bg extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. GGGG", - "d MMMM y '\u0433'. GGGG", - "d.MM.y '\u0433'. GGGG", - "d.MM.yy GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u043d\u0434", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u043b\u044f", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u044f\u0434\u0430", - "\u0447\u0435\u0442\u0432\u044a\u0440\u0442\u044a\u043a", - "\u043f\u0435\u0442\u044a\u043a", - "\u0441\u044a\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0432", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u044f\u043d\u0443", @@ -374,41 +300,15 @@ public class JavaTimeSupplementary_bg extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1. \u0442\u0440\u0438\u043c.", - "2. \u0442\u0440\u0438\u043c.", - "3. \u0442\u0440\u0438\u043c.", - "4. \u0442\u0440\u0438\u043c.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "2. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "3. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - "4. \u0442\u0440\u0438\u043c\u0435\u0441\u0435\u0447\u0438\u0435", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u043f\u0440.\u043e\u0431.", - "\u0441\u043b.\u043e\u0431.", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ca.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ca.java index 8a4064cb006..fa17a859bfd 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ca.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ca.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ca extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1T", + "2T", + "3T", + "4T", + }; + + final String[] sharedQuarterNames = { + "1r trimestre", + "2n trimestre", + "3r trimestre", + "4t trimestre", + }; + + final String[] sharedAmPmMarkers = { + "a. m.", + "p. m.", + }; + + final String[] sharedDayAbbreviations = { + "dg.", + "dl.", + "dt.", + "dc.", + "dj.", + "dv.", + "ds.", + }; + + final String[] sharedDayNames = { + "diumenge", + "dilluns", + "dimarts", + "dimecres", + "dijous", + "divendres", + "dissabte", + }; + + final String[] sharedDayNarrows = { + "dg", + "dl", + "dt", + "dc", + "dj", + "dv", + "ds", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeLongEras = { + "BC", + "eB", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM 'de' y G", + "d MMMM 'de' y G", + "d/M/y G", + "d/M/yy GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1r trimestre", - "2n trimestre", - "3r trimestre", - "4t trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "calendari budista" }, { "calendarname.gregorian", @@ -124,11 +180,7 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { { "field.zone", "fus horari" }, { "islamic.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE d MMMM 'de' y GGGG", @@ -138,82 +190,21 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "dg.", - "dl.", - "dt.", - "dc.", - "dj.", - "dv.", - "ds.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "diumenge", - "dilluns", - "dimarts", - "dimecres", - "dijous", - "divendres", - "dissabte", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "dg", - "dl", - "dt", - "dc", - "dj", - "dv", - "ds", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1r trimestre", - "2n trimestre", - "3r trimestre", - "4t trimestre", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", new String[] { "EEEE, dd MMMM y G", @@ -223,33 +214,13 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { } }, { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "eB", - } - }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - new String[] { - "BC", - "eB", - } - }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM 'de' y G", - "d MMMM 'de' y G", - "d/M/y G", - "d/M/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM 'de' y G", - "d MMMM 'de' y G", - "d/M/y G", - "d/M/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "abans de Crist", @@ -271,11 +242,7 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "EEEE d MMMM 'de' y GGGG", @@ -285,38 +252,11 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "dg.", - "dl.", - "dt.", - "dc.", - "dj.", - "dv.", - "ds.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "diumenge", - "dilluns", - "dimarts", - "dimecres", - "dijous", - "divendres", - "dissabte", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "dg", - "dl", - "dt", - "dc", - "dj", - "dv", - "ds", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "gen.", @@ -369,41 +309,15 @@ public class JavaTimeSupplementary_ca extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1r trimestre", - "2n trimestre", - "3r trimestre", - "4t trimestre", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_cs.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_cs.java index c6b46b60cfe..9467f3e7fdb 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_cs.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_cs.java @@ -72,15 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_cs extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1. \u010dtvrtlet\u00ed", + "2. \u010dtvrtlet\u00ed", + "3. \u010dtvrtlet\u00ed", + "4. \u010dtvrtlet\u00ed", + }; + + final String[] sharedAmPmMarkers = { + "dop.", + "odp.", + }; + + final String[] sharedDatePatterns = { + "EEEE d. MMMM y GGGG", + "d. MMMM y GGGG", + "d. M. y GGGG", + "dd.MM.yy G", + }; + + final String[] sharedDayAbbreviations = { + "ne", + "po", + "\u00fat", + "st", + "\u010dt", + "p\u00e1", + "so", + }; + + final String[] sharedDayNames = { + "ned\u011ble", + "pond\u011bl\u00ed", + "\u00fater\u00fd", + "st\u0159eda", + "\u010dtvrtek", + "p\u00e1tek", + "sobota", + }; + + final String[] sharedDayNarrows = { + "N", + "P", + "\u00da", + "S", + "\u010c", + "P", + "S", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d. MMMM y G", + "d. MMMM y G", + "d. M. y G", + "dd.MM.yy GGGGG", + }; + + final String[] sharedEras = { + "P\u0159ed R. O. C.", + "", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "1. \u010dtvrtlet\u00ed", - "2. \u010dtvrtlet\u00ed", - "3. \u010dtvrtlet\u00ed", - "4. \u010dtvrtlet\u00ed", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Buddhistick\u00fd kalend\u00e1\u0159" }, { "calendarname.gregorian", @@ -116,134 +185,27 @@ public class JavaTimeSupplementary_cs extends OpenListResourceBundle { { "field.zone", "\u010dasov\u00e9 p\u00e1smo" }, { "islamic.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. M. y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "ne", - "po", - "\u00fat", - "st", - "\u010dt", - "p\u00e1", - "so", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "ned\u011ble", - "pond\u011bl\u00ed", - "\u00fater\u00fd", - "st\u0159eda", - "\u010dtvrtek", - "p\u00e1tek", - "sobota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "N", - "P", - "\u00da", - "S", - "\u010c", - "P", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. \u010dtvrtlet\u00ed", - "2. \u010dtvrtlet\u00ed", - "3. \u010dtvrtlet\u00ed", - "4. \u010dtvrtlet\u00ed", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. M. y G", - "dd.MM.yy GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -251,13 +213,7 @@ public class JavaTimeSupplementary_cs extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. M. y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d. MMMM y G", @@ -273,13 +229,7 @@ public class JavaTimeSupplementary_cs extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. M. y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "p\u0159.Kr.", @@ -287,58 +237,17 @@ public class JavaTimeSupplementary_cs extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. M. y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "ne", - "po", - "\u00fat", - "st", - "\u010dt", - "p\u00e1", - "so", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "ned\u011ble", - "pond\u011bl\u00ed", - "\u00fater\u00fd", - "st\u0159eda", - "\u010dtvrtek", - "p\u00e1tek", - "sobota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "N", - "P", - "\u00da", - "S", - "\u010c", - "P", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "P\u0159ed R. O. C.", - "", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "led", @@ -373,77 +282,22 @@ public class JavaTimeSupplementary_cs extends OpenListResourceBundle { "", } }, - { "roc.MonthNarrows", - new String[] { - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "", - } - }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. \u010dtvrtlet\u00ed", - "2. \u010dtvrtlet\u00ed", - "3. \u010dtvrtlet\u00ed", - "4. \u010dtvrtlet\u00ed", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "P\u0159ed R. O. C.", - "", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "dop.", - "odp.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "P\u0159ed R. O. C.", - "", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "P\u0159ed R. O. C.", - "", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_da.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_da.java index 9cc683a9972..31eb458e419 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_da.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_da.java @@ -72,27 +72,91 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_da extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterAbbreviations = { + "1. kvt.", + "2. kvt.", + "3. kvt.", + "4. kvt.", + }; + + final String[] sharedQuarterNames = { + "1. kvartal", + "2. kvartal", + "3. kvartal", + "4. kvartal", + }; + + final String[] sharedDatePatterns = { + "EEEE d. MMMM y GGGG", + "d. MMMM y GGGG", + "d. MMM y GGGG", + "d/M/y", + }; + + final String[] sharedDayAbbreviations = { + "s\u00f8n.", + "man.", + "tir.", + "ons.", + "tor.", + "fre.", + "l\u00f8r.", + }; + + final String[] sharedDayNames = { + "s\u00f8ndag", + "mandag", + "tirsdag", + "onsdag", + "torsdag", + "fredag", + "l\u00f8rdag", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "T", + "O", + "T", + "F", + "L", + }; + + final String[] sharedTimePatterns = { + "HH.mm.ss zzzz", + "HH.mm.ss z", + "HH.mm.ss", + "HH.mm", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d. MMMM y G", + "d. MMMM y G", + "d. MMM y G", + "d/M/y", + }; + + final String[] sharedJavaTimeLongEras = { "f.Kr.", "e.Kr.", }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1. kvt.", - "2. kvt.", - "3. kvt.", - "4. kvt.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "buddhistisk kalender" }, { "calendarname.gregorian", @@ -136,122 +200,23 @@ public class JavaTimeSupplementary_da extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. MMM y GGGG", - "d/M/y", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "s\u00f8n.", - "man.", - "tir.", - "ons.", - "tor.", - "fre.", - "l\u00f8r.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "s\u00f8ndag", - "mandag", - "tirsdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f8rdag", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1. kvt.", - "2. kvt.", - "3. kvt.", - "4. kvt.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d/M/y", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -259,86 +224,25 @@ public class JavaTimeSupplementary_da extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedJavaTimeLongEras }, { "roc.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. MMM y GGGG", - "d/M/y", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "s\u00f8n.", - "man.", - "tir.", - "ons.", - "tor.", - "fre.", - "l\u00f8r.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "s\u00f8ndag", - "mandag", - "tirsdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f8rdag", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -391,53 +295,19 @@ public class JavaTimeSupplementary_da extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1. kvt.", - "2. kvt.", - "3. kvt.", - "4. kvt.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de.java index e4854bb6c02..218afae3246 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de.java @@ -72,19 +72,87 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_de extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterNames = { + "1. Quartal", + "2. Quartal", + "3. Quartal", + "4. Quartal", + }; + + final String[] sharedAmPmMarkers = { + "vorm.", + "nachm.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d. MMMM y GGGG", + "d. MMMM y GGGG", + "dd.MM.y GGGG", + "dd.MM.yy G", + }; + + final String[] sharedDayAbbreviations = { + "So.", + "Mo.", + "Di.", + "Mi.", + "Do.", + "Fr.", + "Sa.", + }; + + final String[] sharedDayNames = { + "Sonntag", + "Montag", + "Dienstag", + "Mittwoch", + "Donnerstag", + "Freitag", + "Samstag", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "D", + "M", + "D", + "F", + "S", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedNarrowAmPmMarkers = { + "vm.", + "nm.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d. MMMM y G", + "d. MMMM y G", + "dd.MM.y G", + "dd.MM.yy GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { "v. Chr.", "n. Chr.", }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "1. Quartal", - "2. Quartal", - "3. Quartal", - "4. Quartal", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Buddhistischer Kalender" }, { "calendarname.gregorian", @@ -120,134 +188,25 @@ public class JavaTimeSupplementary_de extends OpenListResourceBundle { { "field.zone", "Zeitzone" }, { "islamic.AmPmMarkers", - new String[] { - "vorm.", - "nachm.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "So.", - "Mo.", - "Di.", - "Mi.", - "Do.", - "Fr.", - "Sa.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Sonntag", - "Montag", - "Dienstag", - "Mittwoch", - "Donnerstag", - "Freitag", - "Samstag", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "D", - "M", - "D", - "F", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. Quartal", - "2. Quartal", - "3. Quartal", - "4. Quartal", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "vorm.", - "nachm.", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "vm.", - "nm.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.yy GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -255,86 +214,27 @@ public class JavaTimeSupplementary_de extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "roc.AmPmMarkers", - new String[] { - "vorm.", - "nachm.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "So.", - "Mo.", - "Di.", - "Mi.", - "Do.", - "Fr.", - "Sa.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Sonntag", - "Montag", - "Dienstag", - "Mittwoch", - "Donnerstag", - "Freitag", - "Samstag", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "D", - "M", - "D", - "F", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "Jan.", @@ -387,59 +287,19 @@ public class JavaTimeSupplementary_de extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. Quartal", - "2. Quartal", - "3. Quartal", - "4. Quartal", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "vorm.", - "nachm.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "vm.", - "nm.", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de_AT.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de_AT.java index d2c7433aca4..d2a4a1e0b73 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de_AT.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_de_AT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_el.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_el.java index 1a699b83c2e..501b58379f8 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_el.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_el.java @@ -72,23 +72,91 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_el extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "\u03a41", + "\u03a42", + "\u03a43", + "\u03a44", + }; + + final String[] sharedQuarterNames = { + "1\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", + "2\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", + "3\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", + "4\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", + }; + + final String[] sharedAmPmMarkers = { + "\u03c0.\u03bc.", + "\u03bc.\u03bc.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "d/M/y G", + }; + + final String[] sharedDayAbbreviations = { + "\u039a\u03c5\u03c1", + "\u0394\u03b5\u03c5", + "\u03a4\u03c1\u03af", + "\u03a4\u03b5\u03c4", + "\u03a0\u03ad\u03bc", + "\u03a0\u03b1\u03c1", + "\u03a3\u03ac\u03b2", + }; + + final String[] sharedDayNames = { + "\u039a\u03c5\u03c1\u03b9\u03b1\u03ba\u03ae", + "\u0394\u03b5\u03c5\u03c4\u03ad\u03c1\u03b1", + "\u03a4\u03c1\u03af\u03c4\u03b7", + "\u03a4\u03b5\u03c4\u03ac\u03c1\u03c4\u03b7", + "\u03a0\u03ad\u03bc\u03c0\u03c4\u03b7", + "\u03a0\u03b1\u03c1\u03b1\u03c3\u03ba\u03b5\u03c5\u03ae", + "\u03a3\u03ac\u03b2\u03b2\u03b1\u03c4\u03bf", + }; + + final String[] sharedDayNarrows = { + "\u039a", + "\u0394", + "\u03a4", + "\u03a4", + "\u03a0", + "\u03a0", + "\u03a3", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedNarrowAmPmMarkers = { + "\u03c0\u03bc", + "\u03bc\u03bc", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "d/M/y GGGGG", + }; + + final String[] sharedEras = { + "\u03a0\u03c1\u03b9\u03bd R.O.C.", + "R.O.C.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u03a41", - "\u03a42", - "\u03a43", - "\u03a44", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "2\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "3\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "4\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0392\u03bf\u03c5\u03b4\u03b9\u03c3\u03c4\u03b9\u03ba\u03cc \u03b7\u03bc\u03b5\u03c1\u03bf\u03bb\u03cc\u03b3\u03b9\u03bf" }, { "calendarname.gregorian", @@ -124,110 +192,27 @@ public class JavaTimeSupplementary_el extends OpenListResourceBundle { { "field.zone", "\u03b6\u03ce\u03bd\u03b7 \u03ce\u03c1\u03b1\u03c2" }, { "islamic.AmPmMarkers", - new String[] { - "\u03c0.\u03bc.", - "\u03bc.\u03bc.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/M/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u039a\u03c5\u03c1", - "\u0394\u03b5\u03c5", - "\u03a4\u03c1\u03af", - "\u03a4\u03b5\u03c4", - "\u03a0\u03ad\u03bc", - "\u03a0\u03b1\u03c1", - "\u03a3\u03ac\u03b2", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u039a\u03c5\u03c1\u03b9\u03b1\u03ba\u03ae", - "\u0394\u03b5\u03c5\u03c4\u03ad\u03c1\u03b1", - "\u03a4\u03c1\u03af\u03c4\u03b7", - "\u03a4\u03b5\u03c4\u03ac\u03c1\u03c4\u03b7", - "\u03a0\u03ad\u03bc\u03c0\u03c4\u03b7", - "\u03a0\u03b1\u03c1\u03b1\u03c3\u03ba\u03b5\u03c5\u03ae", - "\u03a3\u03ac\u03b2\u03b2\u03b1\u03c4\u03bf", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u039a", - "\u0394", - "\u03a4", - "\u03a4", - "\u03a0", - "\u03a0", - "\u03a3", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "\u03a41", - "\u03a42", - "\u03a43", - "\u03a44", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "2\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "3\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "4\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u03c0.\u03bc.", - "\u03bc.\u03bc.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u03c0\u03bc", - "\u03bc\u03bc", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -235,13 +220,7 @@ public class JavaTimeSupplementary_el extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d MMMM, y G", @@ -257,13 +236,7 @@ public class JavaTimeSupplementary_el extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u03c0.\u03a7.", @@ -271,58 +244,17 @@ public class JavaTimeSupplementary_el extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u03c0.\u03bc.", - "\u03bc.\u03bc.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/M/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u039a\u03c5\u03c1", - "\u0394\u03b5\u03c5", - "\u03a4\u03c1\u03af", - "\u03a4\u03b5\u03c4", - "\u03a0\u03ad\u03bc", - "\u03a0\u03b1\u03c1", - "\u03a3\u03ac\u03b2", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u039a\u03c5\u03c1\u03b9\u03b1\u03ba\u03ae", - "\u0394\u03b5\u03c5\u03c4\u03ad\u03c1\u03b1", - "\u03a4\u03c1\u03af\u03c4\u03b7", - "\u03a4\u03b5\u03c4\u03ac\u03c1\u03c4\u03b7", - "\u03a0\u03ad\u03bc\u03c0\u03c4\u03b7", - "\u03a0\u03b1\u03c1\u03b1\u03c3\u03ba\u03b5\u03c5\u03ae", - "\u03a3\u03ac\u03b2\u03b2\u03b1\u03c4\u03bf", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u039a", - "\u0394", - "\u03a4", - "\u03a4", - "\u03a0", - "\u03a0", - "\u03a3", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\u03a0\u03c1\u03b9\u03bd R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "\u0399\u03b1\u03bd", @@ -375,59 +307,21 @@ public class JavaTimeSupplementary_el extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u03a41", - "\u03a42", - "\u03a43", - "\u03a44", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "2\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "3\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - "4\u03bf \u03c4\u03c1\u03af\u03bc\u03b7\u03bd\u03bf", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u03c0.\u03bc.", - "\u03bc.\u03bc.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "\u03a0\u03c1\u03b9\u03bd R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u03c0\u03bc", - "\u03bc\u03bc", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "\u03a0\u03c1\u03b9\u03bd R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "\u03a0\u03c1\u03b9\u03bd R.O.C.", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_AU.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_AU.java index f848483c897..a2a444b4a8e 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_AU.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_AU.java @@ -72,123 +72,100 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_AU extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "am", + "pm", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd/MM/y G", + }; + + final String[] sharedDayAbbreviations = { + "Sun.", + "Mon.", + "Tue.", + "Wed.", + "Thu.", + "Fri.", + "Sat.", + }; + + final String[] sharedDayNarrows = { + "Su.", + "M.", + "Tu.", + "W.", + "Th.", + "F.", + "Sa.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd/MM/y GGGGG", + }; + + final String[] sharedMonthNarrows = { + "Jan.", + "Feb.", + "Mar.", + "Apr.", + "May", + "Jun.", + "Jul.", + "Aug.", + "Sep.", + "Oct.", + "Nov.", + "Dec.", + "", + }; + return new Object[][] { { "field.dayperiod", "am/pm" }, { "islamic.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Sun.", - "Mon.", - "Tue.", - "Wed.", - "Thu.", - "Fri.", - "Sat.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNarrows", - new String[] { - "Su.", - "M.", - "Tu.", - "W.", - "Th.", - "F.", - "Sa.", - } - }, + sharedDayNarrows }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.japanese.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, { "roc.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Sun.", - "Mon.", - "Tue.", - "Wed.", - "Thu.", - "Fri.", - "Sat.", - } - }, + sharedDayAbbreviations }, { "roc.DayNarrows", - new String[] { - "Su.", - "M.", - "Tu.", - "W.", - "Th.", - "F.", - "Sa.", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", - new String[] { - "Jan.", - "Feb.", - "Mar.", - "Apr.", - "May", - "Jun.", - "Jul.", - "Aug.", - "Sep.", - "Oct.", - "Nov.", - "Dec.", - "", - } - }, + sharedMonthNarrows }, { "roc.MonthNarrows", - new String[] { - "Jan.", - "Feb.", - "Mar.", - "Apr.", - "May", - "Jun.", - "Jul.", - "Aug.", - "Sep.", - "Oct.", - "Nov.", - "Dec.", - "", - } - }, + sharedMonthNarrows }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_CA.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_CA.java index 1aa0e8368d1..caf541ad944 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_CA.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_CA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,55 +72,33 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_CA extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "EEEE, MMMM d, y GGGG", + "MMMM d, y GGGG", + "MMM d, y GGGG", + "G y-MM-dd", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, MMMM d, y G", + "MMMM d, y G", + "MMM d, y G", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "EEEE, MMMM d, y GGGG", - "MMMM d, y GGGG", - "MMM d, y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, MMMM d, y G", - "MMMM d, y G", - "MMM d, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE, MMMM d, y GGGG", - "MMMM d, y GGGG", - "MMM d, y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_GB.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_GB.java index ae5224f7873..894b74cbe3f 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_GB.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_GB.java @@ -72,61 +72,59 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_GB extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "am", + "pm", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd/MM/y G", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd/MM/y GGGGG", + }; + return new Object[][] { { "field.dayperiod", "am/pm" }, { "islamic.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, - { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.japanese.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, { "roc.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "am", - "pm", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IE.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IE.java index f199240fe7c..fef27be727c 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IE.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IE.java @@ -72,45 +72,43 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_IE extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "GGGG y MMMM d", + "GGGG y MMM d", + "G y-MM-dd", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "G y MMMM d", + "G y MMM d", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "islamic.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "GGGG y MMMM d", - "GGGG y MMM d", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE d MMMM y G", @@ -120,35 +118,13 @@ public class JavaTimeSupplementary_en_IE extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "roc.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "GGGG y MMMM d", - "GGGG y MMM d", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IN.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IN.java index afe20322842..0c2d23db317 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IN.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_IN.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_IN extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "GGGG y MMMM d", + "dd-MMM-y GGGG", + "G y-MM-dd", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "G y MMMM d", + "dd-MMM-y G", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "GGGG y MMMM d", - "dd-MMM-y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "dd-MMM-y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "dd-MMM-y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE d MMMM y G", @@ -106,21 +102,9 @@ public class JavaTimeSupplementary_en_IN extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "G y MMMM d", - "dd-MMM-y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "GGGG y MMMM d", - "dd-MMM-y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_MT.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_MT.java index 22c721ec69c..af6d84646ba 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_MT.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_MT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -72,39 +72,36 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_MT extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "dd MMMM y GGGG", + "dd MMM y GGGG", + "G y-MM-dd", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "dd MMMM y G", + "dd MMM y G", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, MMMM d, y G", @@ -114,29 +111,11 @@ public class JavaTimeSupplementary_en_MT extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_NZ.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_NZ.java index 30c7f415ba6..cedbd26f8c5 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_NZ.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_NZ.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_NZ extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "d/MM/y GGGG", + "d/MM/y G", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "d/MM/y G", + "d/MM/y GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/y G", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, MMMM d, y G", @@ -106,21 +102,9 @@ public class JavaTimeSupplementary_en_NZ extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/y G", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_SG.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_SG.java index 0c2e8626154..9f743599d4e 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_SG.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_SG.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,27 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_SG extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "d/M/yy G", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "d/M/yy GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/M/yy G", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, MMMM d, y G", @@ -106,21 +102,9 @@ public class JavaTimeSupplementary_en_SG extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/M/yy G", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_ZA.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_ZA.java index c30577d23ae..69ba92b9f8f 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_ZA.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_en_ZA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,55 +72,33 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_en_ZA extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "EEEE, dd MMMM y GGGG", + "dd MMMM y GGGG", + "dd MMM y GGGG", + "G y/MM/dd", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, dd MMMM y G", + "dd MMMM y G", + "dd MMM y G", + "GGGGG y/MM/dd", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y GGGG", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "G y/MM/dd", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "GGGGG y/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y GGGG", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "G y/MM/dd", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es.java index 7b288a31722..a19188834c0 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es.java @@ -72,23 +72,86 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "T1", + "T2", + "T3", + "T4", + }; + + final String[] sharedQuarterNames = { + "1.er trimestre", + "2.\u00ba trimestre", + "3.er trimestre", + "4.\u00ba trimestre", + }; + + final String[] sharedAmPmMarkers = { + "a. m.", + "p. m.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d 'de' MMMM 'de' y GGGG", + "d 'de' MMMM 'de' y GGGG", + "d/M/y GGGG", + "d/M/yy GGGG", + }; + + final String[] sharedDayAbbreviations = { + "dom.", + "lun.", + "mar.", + "mi\u00e9.", + "jue.", + "vie.", + "s\u00e1b.", + }; + + final String[] sharedDayNames = { + "domingo", + "lunes", + "martes", + "mi\u00e9rcoles", + "jueves", + "viernes", + "s\u00e1bado", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "X", + "J", + "V", + "S", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss (zzzz)", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d 'de' MMMM 'de' y G", + "d 'de' MMMM 'de' y G", + "d/M/y G", + "d/M/yy G", + }; + + final String[] sharedEras = { + "antes de R.O.C.", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1.er trimestre", - "2.\u00ba trimestre", - "3.er trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "calendario budista" }, { "calendarname.gregorian", @@ -124,134 +187,27 @@ public class JavaTimeSupplementary_es extends OpenListResourceBundle { { "field.zone", "zona horaria" }, { "islamic.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y GGGG", - "d 'de' MMMM 'de' y GGGG", - "d/M/y GGGG", - "d/M/yy GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "dom.", - "lun.", - "mar.", - "mi\u00e9.", - "jue.", - "vie.", - "s\u00e1b.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "domingo", - "lunes", - "martes", - "mi\u00e9rcoles", - "jueves", - "viernes", - "s\u00e1bado", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "X", - "J", - "V", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1.er trimestre", - "2.\u00ba trimestre", - "3.er trimestre", - "4.\u00ba trimestre", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss (zzzz)", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "d/M/y G", - "d/M/yy G", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -259,13 +215,7 @@ public class JavaTimeSupplementary_es extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "d/M/y G", - "d/M/yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -281,13 +231,7 @@ public class JavaTimeSupplementary_es extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "d/M/y G", - "d/M/yy G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "antes de Cristo", @@ -295,58 +239,17 @@ public class JavaTimeSupplementary_es extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y GGGG", - "d 'de' MMMM 'de' y GGGG", - "d/M/y GGGG", - "d/M/yy GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "dom.", - "lun.", - "mar.", - "mi\u00e9.", - "jue.", - "vie.", - "s\u00e1b.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "domingo", - "lunes", - "martes", - "mi\u00e9rcoles", - "jueves", - "viernes", - "s\u00e1bado", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "X", - "J", - "V", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "antes de R.O.C.", - "", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "ene.", @@ -399,59 +302,21 @@ public class JavaTimeSupplementary_es extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1.er trimestre", - "2.\u00ba trimestre", - "3.er trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss (zzzz)", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "antes de R.O.C.", - "", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a. m.", - "p. m.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "antes de R.O.C.", - "", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "antes de R.O.C.", - "", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_AR.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_AR.java new file mode 100644 index 00000000000..fb9111a1663 --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_AR.java @@ -0,0 +1,180 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_es_AR extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", + new String[] { + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", + } + }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_BO.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_BO.java new file mode 100644 index 00000000000..c540c54358e --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_BO.java @@ -0,0 +1,182 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_es_BO extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", + new String[] { + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", + } + }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CL.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CL.java index 3e4213605db..9ff73c416d9 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CL.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CL.java @@ -72,47 +72,74 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_CL extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1.\u00b0 trimestre", + "2.\u00b0 trimestre", + "3.\u00b0 trimestre", + "4.\u00ba trimestre", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "dd-MM-y GGGG", + "dd-MM-y G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "dd-MM-y G", + "dd-MM-y GGGGG", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "1.\u00b0 trimestre", - "2.\u00b0 trimestre", - "3.\u00b0 trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "dd-MM-y GGGG", - "dd-MM-y G", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.QuarterNames", - new String[] { - "1.\u00b0 trimestre", - "2.\u00b0 trimestre", - "3.\u00b0 trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd-MM-y G", - "dd-MM-y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd-MM-y G", - "dd-MM-y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -122,29 +149,38 @@ public class JavaTimeSupplementary_es_CL extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd-MM-y G", - "dd-MM-y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthNarrows", new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "dd-MM-y GGGG", - "dd-MM-y G", + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.QuarterNames", - new String[] { - "1.\u00b0 trimestre", - "2.\u00b0 trimestre", - "3.\u00b0 trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CO.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CO.java index d7d08bf676d..fd5aa17577b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CO.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CO.java @@ -72,50 +72,61 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_CO extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "d/MM/y GGGG", + "d/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "d/MM/y G", + "d/MM/yy GGGGG", + }; + return new Object[][] { + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/yy G", - } - }, + sharedDatePatterns }, { "islamic.DayNarrows", - new String[] { - "d", - "l", - "m", - "m", - "j", - "v", - "s", - } - }, + sharedDayNarrows }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -125,40 +136,36 @@ public class JavaTimeSupplementary_es_CO extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/yy G", - } - }, + sharedDatePatterns }, { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthNarrows", new String[] { - "d", - "l", + "e", + "f", "m", + "a", "m", "j", - "v", + "j", + "a", "s", + "o", + "n", + "d", + "", } }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CR.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CR.java new file mode 100644 index 00000000000..b8530cd0a8b --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_CR.java @@ -0,0 +1,182 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_es_CR extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", + new String[] { + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", + } + }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_DO.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_DO.java index aa86aeed53b..3bd08aa334f 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_DO.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_DO.java @@ -72,15 +72,54 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_DO extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "dd/MM/y GGGG", + "G y-MM-dd", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "dd/MM/y G", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, + { "field.dayperiod", + "a.m./p.m." }, { "field.era", "Era" }, { "field.minute", @@ -95,78 +134,76 @@ public class JavaTimeSupplementary_es_DO extends OpenListResourceBundle { "D\u00eda de la semana" }, { "field.year", "A\u00f1o" }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "dd/MM/y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd/MM/y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd/MM/y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "dd/MM/y G", - "GGGGG y-MM-dd", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", } }, - { "roc.DatePatterns", + { "roc.MonthNarrows", new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "dd/MM/y GGGG", - "G y-MM-dd", + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_EC.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_EC.java new file mode 100644 index 00000000000..4a1e4a5ced7 --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_EC.java @@ -0,0 +1,182 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_es_EC extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", + new String[] { + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", + } + }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_GT.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_GT.java index e753081ccfa..d5662cdfe1d 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_GT.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_GT.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,63 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_GT extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "d/MM/y GGGG", + "d/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "d/MM/y G", + "d/MM/yy GGGGG", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/yy G", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -106,21 +138,53 @@ public class JavaTimeSupplementary_es_GT extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d/MM/y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d/MM/y GGGG", - "d/MM/yy G", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", } }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_HN.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_HN.java index 4c28ef30fc8..9e0a481afbc 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_HN.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_HN.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,63 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_HN extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE dd 'de' MMMM 'de' y GGGG", + "dd 'de' MMMM 'de' y GGGG", + "GGGG y MMM d", + "G y-MM-dd", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE dd 'de' MMMM 'de' y G", + "dd 'de' MMMM 'de' y G", + "G y MMM d", + "GGGGG y-MM-dd", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE dd 'de' MMMM 'de' y GGGG", - "dd 'de' MMMM 'de' y GGGG", - "GGGG y MMM d", - "G y-MM-dd", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE dd 'de' MMMM 'de' y G", - "dd 'de' MMMM 'de' y G", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE dd 'de' MMMM 'de' y G", - "dd 'de' MMMM 'de' y G", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE dd 'de' MMMM 'de' y G", @@ -106,21 +138,53 @@ public class JavaTimeSupplementary_es_HN extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE dd 'de' MMMM 'de' y G", - "dd 'de' MMMM 'de' y G", - "G y MMM d", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "EEEE dd 'de' MMMM 'de' y GGGG", - "dd 'de' MMMM 'de' y GGGG", - "GGGG y MMM d", - "G y-MM-dd", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", } }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_MX.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_MX.java index 07ca85c298e..4487bc676c0 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_MX.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_MX.java @@ -72,96 +72,102 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_MX extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1er. trim.", + "2\u00ba. trim.", + "3er. trim.", + "4\u00ba trim.", + }; + + final String[] sharedQuarterNames = { + "1er. trimestre", + "2\u00ba. trimestre", + "3er. trimestre", + "4\u00ba trimestre", + }; + + final String[] sharedQuarterNarrows = { + "1T", + "2T", + "3T", + "4T", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "d MMM, y GGGG", + "G y-MM-dd", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "M", + "J", + "V", + "S", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "d MMM, y G", + "GGGGG y-MM-dd", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1er. trim.", - "2\u00ba. trim.", - "3er. trim.", - "4\u00ba trim.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1er. trimestre", - "2\u00ba. trimestre", - "3er. trimestre", - "4\u00ba trimestre", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterNarrows }, { "calendarname.gregorian", "Calendario gregoriano" }, { "calendarname.gregory", "Calendario gregoriano" }, { "calendarname.roc", "calendario minguo" }, + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d MMM, y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1er. trim.", - "2\u00ba. trim.", - "3er. trim.", - "4\u00ba trim.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1er. trimestre", - "2\u00ba. trimestre", - "3er. trimestre", - "4\u00ba trimestre", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d MMM, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d MMM, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -171,32 +177,13 @@ public class JavaTimeSupplementary_es_MX extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "d MMM, y G", - "GGGGG y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "d MMM, y GGGG", - "G y-MM-dd", - } - }, + sharedDatePatterns }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "ene", @@ -214,30 +201,35 @@ public class JavaTimeSupplementary_es_MX extends OpenListResourceBundle { "", } }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, { "roc.QuarterAbbreviations", - new String[] { - "1er. trim.", - "2\u00ba. trim.", - "3er. trim.", - "4\u00ba trim.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1er. trimestre", - "2\u00ba. trimestre", - "3er. trimestre", - "4\u00ba trimestre", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1T", - "2T", - "3T", - "4T", - } - }, + sharedQuarterNarrows }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PA.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PA.java index 320f4436c0a..313705ba3a8 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PA.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PA.java @@ -72,63 +72,76 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_PA extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1er. trimestre", + "2do. trimestre", + "3er. trimestre", + "4.\u00ba trimestre", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "MM/dd/y GGGG", + "MM/dd/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "MM/dd/y G", + "MM/dd/yy GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1er. trimestre", - "2do. trimestre", - "3er. trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "1er. trimestre", - "2do. trimestre", - "3er. trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "MM/dd/y GGGG", - "MM/dd/yy G", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.QuarterNames", - new String[] { - "1er. trimestre", - "2do. trimestre", - "3er. trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -138,37 +151,55 @@ public class JavaTimeSupplementary_es_PA extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", } }, - { "roc.DatePatterns", + { "roc.MonthNarrows", new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "MM/dd/y GGGG", - "MM/dd/yy G", + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.QuarterNames", - new String[] { - "1er. trimestre", - "2do. trimestre", - "3er. trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PE.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PE.java index c4949c8e86e..a63e59eed44 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PE.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PE.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,31 +72,63 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_PE extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "d/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "d/MM/yy GGGGG", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/MM/yy G", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -106,21 +138,13 @@ public class JavaTimeSupplementary_es_PE extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/MM/yy G", - } - }, + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "ene.", @@ -155,6 +179,29 @@ public class JavaTimeSupplementary_es_PE extends OpenListResourceBundle { "", } }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PR.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PR.java index ef45f9665ef..ddd6450ed41 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PR.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PR.java @@ -72,39 +72,63 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_PR extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "MM/dd/y GGGG", + "MM/dd/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "MM/dd/y G", + "MM/dd/yy GGGGG", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "MM/dd/y GGGG", - "MM/dd/yy G", - } - }, + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -114,29 +138,53 @@ public class JavaTimeSupplementary_es_PR extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "MM/dd/y G", - "MM/dd/yy GGGGG", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", } }, - { "roc.DatePatterns", + { "roc.MonthNarrows", new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "MM/dd/y GGGG", - "MM/dd/yy G", + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PY.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PY.java new file mode 100644 index 00000000000..ebd09ebc5de --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_PY.java @@ -0,0 +1,163 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_es_PY extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_US.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_US.java index 6cf5be45e24..f12835c1996 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_US.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_US.java @@ -72,27 +72,75 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_US extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedAbbreviatedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, { "islamic.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAbbreviatedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "a.C.", @@ -100,25 +148,51 @@ public class JavaTimeSupplementary_es_US extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthAbbreviations", new String[] { - "AM", - "PM", + "ene.", + "feb.", + "mar.", + "abr.", + "may.", + "jun.", + "jul.", + "ago.", + "sep.", + "oct.", + "nov.", + "dic.", + "", + } + }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAbbreviatedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_UY.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_UY.java index 2247c14e6ca..bcae639ef76 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_UY.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_UY.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,7 +72,71 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_UY extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + return new Object[][] { + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, + { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "ene.", @@ -107,6 +171,29 @@ public class JavaTimeSupplementary_es_UY extends OpenListResourceBundle { "", } }, + { "roc.MonthNarrows", + new String[] { + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", + } + }, + { "roc.TimePatterns", + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_VE.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_VE.java index 2b093429cfe..df4ad91ae02 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_VE.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_es_VE.java @@ -72,55 +72,109 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_es_VE extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1er trimestre", + "2do trimestre", + "3er trimestre", + "4to trimestre", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "dd/MM/yy G", + }; + + final String[] sharedDayNarrows = { + "d", + "l", + "m", + "m", + "j", + "v", + "s", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "dd/MM/yy GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1er trimestre", - "2do trimestre", - "3er trimestre", - "4to trimestre", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "1er trimestre", - "2do trimestre", - "3er trimestre", - "4to trimestre", - } - }, + sharedQuarterNames }, + { "field.dayperiod", + "a.m./p.m." }, + { "field.zone", + "Zona horaria" }, + { "islamic.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.DatePatterns", + sharedDatePatterns }, + { "islamic.DayNarrows", + sharedDayNarrows }, { "islamic.QuarterNames", - new String[] { - "1er trimestre", - "2do trimestre", - "3er trimestre", - "4to trimestre", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", + sharedTimePatterns }, + { "islamic.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "islamic.narrow.AmPmMarkers", + sharedAmPmMarkers }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.DatePatterns", + sharedDatePatterns }, + { "roc.DayNarrows", + sharedDayNarrows }, + { "roc.MonthNarrows", new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", + "e", + "f", + "m", + "a", + "m", + "j", + "j", + "a", + "s", + "o", + "n", + "d", + "", } }, { "roc.QuarterNames", - new String[] { - "1er trimestre", - "2do trimestre", - "3er trimestre", - "4to trimestre", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, + { "roc.abbreviated.AmPmMarkers", + sharedAmPmMarkers }, + { "roc.narrow.AmPmMarkers", + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_et.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_et.java index 7424a3ce3b4..e8df6930c81 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_et.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_et.java @@ -72,23 +72,71 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_et extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "1. kvartal", + "2. kvartal", + "3. kvartal", + "4. kvartal", + }; + + final String[] sharedDatePatterns = { + "EEEE, d. MMMM y GGGG", + "d. MMMM y GGGG", + "dd.MM.y GGGG", + "dd.MM.y G", + }; + + final String[] sharedDayNarrows = { + "P", + "E", + "T", + "K", + "N", + "R", + "L", + }; + + final String[] sharedDayNames = { + "p\u00fchap\u00e4ev", + "esmasp\u00e4ev", + "teisip\u00e4ev", + "kolmap\u00e4ev", + "neljap\u00e4ev", + "reede", + "laup\u00e4ev", + }; + + final String[] sharedTimePatterns = { + "H:mm.ss zzzz", + "H:mm.ss z", + "H:mm.ss", + "H:mm", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d. MMMM y G", + "d. MMMM y G", + "dd.MM.y G", + "dd.MM.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "budistlik kalender" }, { "calendarname.gregorian", @@ -130,108 +178,27 @@ public class JavaTimeSupplementary_et extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "P", - "E", - "T", - "K", - "N", - "R", - "L", - } - }, + sharedDayNarrows }, { "islamic.DayNames", - new String[] { - "p\u00fchap\u00e4ev", - "esmasp\u00e4ev", - "teisip\u00e4ev", - "kolmap\u00e4ev", - "neljap\u00e4ev", - "reede", - "laup\u00e4ev", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "P", - "E", - "T", - "K", - "N", - "R", - "L", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm.ss zzzz", - "H:mm.ss z", - "H:mm.ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "enne Kristust", @@ -239,66 +206,21 @@ public class JavaTimeSupplementary_et extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "e.m.a.", "m.a.j.", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "P", - "E", - "T", - "K", - "N", - "R", - "L", - } - }, + sharedDayNarrows }, { "roc.DayNames", - new String[] { - "p\u00fchap\u00e4ev", - "esmasp\u00e4ev", - "teisip\u00e4ev", - "kolmap\u00e4ev", - "neljap\u00e4ev", - "reede", - "laup\u00e4ev", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "P", - "E", - "T", - "K", - "N", - "R", - "L", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "jaan", @@ -351,35 +273,13 @@ public class JavaTimeSupplementary_et extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm.ss zzzz", - "H:mm.ss z", - "H:mm.ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fi.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fi.java index 520af848837..8a935e09d6b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fi.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fi.java @@ -72,23 +72,102 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_fi extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1. nelj.", + "2. nelj.", + "3. nelj.", + "4. nelj.", + }; + + final String[] sharedQuarterNames = { + "1. nelj\u00e4nnes", + "2. nelj\u00e4nnes", + "3. nelj\u00e4nnes", + "4. nelj\u00e4nnes", + }; + + final String[] sharedAmPmMarkers = { + "ap.", + "ip.", + }; + + final String[] sharedDatePatterns = { + "EEEE d. MMMM y GGGG", + "d. MMMM y GGGG", + "d.M.y GGGG", + "d.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "su", + "ma", + "ti", + "ke", + "to", + "pe", + "la", + }; + + final String[] sharedDayNames = { + "sunnuntaina", + "maanantaina", + "tiistaina", + "keskiviikkona", + "torstaina", + "perjantaina", + "lauantaina", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "T", + "K", + "T", + "P", + "L", + }; + + final String[] sharedTimePatterns = { + "H.mm.ss zzzz", + "H.mm.ss z", + "H.mm.ss", + "H.mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "cccc d. MMMM y G", + "d. MMMM y G", + "d.M.y G", + "d.M.y GGGGG", + }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + + final String[] sharedMonthNames = { + "tammikuuta", + "helmikuuta", + "maaliskuuta", + "huhtikuuta", + "toukokuuta", + "kes\u00e4kuuta", + "hein\u00e4kuuta", + "elokuuta", + "syyskuuta", + "lokakuuta", + "marraskuuta", + "joulukuuta", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1. nelj.", - "2. nelj.", - "3. nelj.", - "4. nelj.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. nelj\u00e4nnes", - "2. nelj\u00e4nnes", - "3. nelj\u00e4nnes", - "4. nelj\u00e4nnes", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "buddhalainen kalenteri" }, { "calendarname.gregorian", @@ -126,52 +205,15 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { { "field.zone", "aikavy\u00f6hyke" }, { "islamic.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "su", - "ma", - "ti", - "ke", - "to", - "pe", - "la", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "sunnuntaina", - "maanantaina", - "tiistaina", - "keskiviikkona", - "torstaina", - "perjantaina", - "lauantaina", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "T", - "K", - "T", - "P", - "L", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "muharram", @@ -190,49 +232,15 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "1. nelj.", - "2. nelj.", - "3. nelj.", - "4. nelj.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. nelj\u00e4nnes", - "2. nelj\u00e4nnes", - "3. nelj\u00e4nnes", - "4. nelj\u00e4nnes", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H.mm.ss zzzz", - "H.mm.ss z", - "H.mm.ss", - "H.mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "java.time.DatePatterns", new String[] { "cccc d. MMMM y", @@ -242,19 +250,7 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "java.time.buddhist.DatePatterns", - new String[] { - "cccc d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -262,21 +258,9 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "cccc d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "cccc d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "ennen Kristuksen syntym\u00e4\u00e4", @@ -284,13 +268,7 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "cccc d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "eKr.", @@ -298,92 +276,21 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "su", - "ma", - "ti", - "ke", - "to", - "pe", - "la", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "sunnuntaina", - "maanantaina", - "tiistaina", - "keskiviikkona", - "torstaina", - "perjantaina", - "lauantaina", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "T", - "K", - "T", - "P", - "L", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", - new String[] { - "tammikuuta", - "helmikuuta", - "maaliskuuta", - "huhtikuuta", - "toukokuuta", - "kes\u00e4kuuta", - "hein\u00e4kuuta", - "elokuuta", - "syyskuuta", - "lokakuuta", - "marraskuuta", - "joulukuuta", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "tammikuuta", - "helmikuuta", - "maaliskuuta", - "huhtikuuta", - "toukokuuta", - "kes\u00e4kuuta", - "hein\u00e4kuuta", - "elokuuta", - "syyskuuta", - "lokakuuta", - "marraskuuta", - "joulukuuta", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", new String[] { "T", @@ -402,59 +309,21 @@ public class JavaTimeSupplementary_fi extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1. nelj.", - "2. nelj.", - "3. nelj.", - "4. nelj.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. nelj\u00e4nnes", - "2. nelj\u00e4nnes", - "3. nelj\u00e4nnes", - "4. nelj\u00e4nnes", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H.mm.ss zzzz", - "H.mm.ss z", - "H.mm.ss", - "H.mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "ap.", - "ip.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr.java index e89746efede..0e86ade889a 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr.java @@ -72,27 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_fr extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimebuddhistlongEras = { + final String[] sharedQuarterAbbreviations = { + "T1", + "T2", + "T3", + "T4", + }; + + final String[] sharedQuarterNames = { + "1er trimestre", + "2e trimestre", + "3e trimestre", + "4e trimestre", + }; + + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd/MM/y G", + }; + + final String[] sharedDayAbbreviations = { + "dim.", + "lun.", + "mar.", + "mer.", + "jeu.", + "ven.", + "sam.", + }; + + final String[] sharedDayNames = { + "dimanche", + "lundi", + "mardi", + "mercredi", + "jeudi", + "vendredi", + "samedi", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "M", + "J", + "V", + "S", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd/MM/y GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { "BC", "\u00e8re bouddhiste", }; + + final String[] sharedEras = { + "avant RdC", + "RdC", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1er trimestre", - "2e trimestre", - "3e trimestre", - "4e trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "calendrier bouddhiste" }, { "calendarname.gregorian", @@ -128,58 +185,15 @@ public class JavaTimeSupplementary_fr extends OpenListResourceBundle { { "field.zone", "fuseau horaire" }, { "islamic.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "dim.", - "lun.", - "mar.", - "mer.", - "jeu.", - "ven.", - "sam.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "dimanche", - "lundi", - "mardi", - "mercredi", - "jeudi", - "vendredi", - "samedi", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", new String[] { "mouh.", @@ -215,89 +229,21 @@ public class JavaTimeSupplementary_fr extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1er trimestre", - "2e trimestre", - "3e trimestre", - "4e trimestre", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedQuarterNames }, { "islamic.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "avant J\u00e9sus-Christ", @@ -305,72 +251,23 @@ public class JavaTimeSupplementary_fr extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "BC", "ap. J.-C.", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "dim.", - "lun.", - "mar.", - "mer.", - "jeu.", - "ven.", - "sam.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "dimanche", - "lundi", - "mardi", - "mercredi", - "jeudi", - "vendredi", - "samedi", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "avant RdC", - "RdC", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "janv.", @@ -423,53 +320,15 @@ public class JavaTimeSupplementary_fr extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1er trimestre", - "2e trimestre", - "3e trimestre", - "4e trimestre", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.long.Eras", - new String[] { - "avant RdC", - "RdC", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedEras }, { "roc.narrow.Eras", - new String[] { - "avant RdC", - "RdC", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "avant RdC", - "RdC", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_BE.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_BE.java index 20d68a2ce2b..587befa05bf 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_BE.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_BE.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,6 +72,20 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_fr_BE extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedTimePatterns = { + "H 'h' mm 'min' ss 's' zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "d/MM/yy GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", new String[] { @@ -82,37 +96,13 @@ public class JavaTimeSupplementary_fr_BE extends OpenListResourceBundle { } }, { "islamic.TimePatterns", - new String[] { - "H 'h' mm 'min' ss 's' zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", new String[] { "G y MMMM d, EEEE", @@ -130,13 +120,7 @@ public class JavaTimeSupplementary_fr_BE extends OpenListResourceBundle { } }, { "roc.TimePatterns", - new String[] { - "H 'h' mm 'min' ss 's' zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CA.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CA.java index 14bca283e02..dbf796fba1f 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CA.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CA.java @@ -72,6 +72,18 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_fr_CA extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "yy-MM-dd GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", new String[] { @@ -82,19 +94,9 @@ public class JavaTimeSupplementary_fr_CA extends OpenListResourceBundle { } }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "yy-MM-dd GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", new String[] { "EEEE d MMMM y G", @@ -104,13 +106,7 @@ public class JavaTimeSupplementary_fr_CA extends OpenListResourceBundle { } }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "yy-MM-dd GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", new String[] { "G y MMMM d, EEEE", @@ -128,11 +124,7 @@ public class JavaTimeSupplementary_fr_CA extends OpenListResourceBundle { } }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CH.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CH.java index 9a61b08c1ee..74a8d790ab7 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CH.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_fr_CH.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,6 +72,20 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_fr_CH extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedTimePatterns = { + "HH.mm:ss 'h' zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd.MM.yy GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", new String[] { @@ -82,37 +96,13 @@ public class JavaTimeSupplementary_fr_CH extends OpenListResourceBundle { } }, { "islamic.TimePatterns", - new String[] { - "HH.mm:ss 'h' zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", new String[] { "EEEE, d MMMM y G", @@ -130,13 +120,7 @@ public class JavaTimeSupplementary_fr_CH extends OpenListResourceBundle { } }, { "roc.TimePatterns", - new String[] { - "HH.mm:ss 'h' zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ga.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ga.java index ed2df7530e1..4d1debee254 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ga.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ga.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ga extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "R1", + "R2", + "R3", + "R4", + }; + + final String[] sharedQuarterNames = { + "1\u00fa r\u00e1ithe", + "2\u00fa r\u00e1ithe", + "3\u00fa r\u00e1ithe", + "4\u00fa r\u00e1ithe", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd/MM/y G", + }; + + final String[] sharedDayAbbreviations = { + "Domh", + "Luan", + "M\u00e1irt", + "C\u00e9ad", + "D\u00e9ar", + "Aoine", + "Sath", + }; + + final String[] sharedDayNames = { + "D\u00e9 Domhnaigh", + "D\u00e9 Luain", + "D\u00e9 M\u00e1irt", + "D\u00e9 C\u00e9adaoin", + "D\u00e9ardaoin", + "D\u00e9 hAoine", + "D\u00e9 Sathairn", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "C", + "D", + "A", + "S", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd/MM/y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "R1", - "R2", - "R3", - "R4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1\u00fa r\u00e1ithe", - "2\u00fa r\u00e1ithe", - "3\u00fa r\u00e1ithe", - "4\u00fa r\u00e1ithe", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "F\u00e9ilire B\u00fada\u00edoch" }, { "calendarname.gregorian", @@ -122,120 +178,29 @@ public class JavaTimeSupplementary_ga extends OpenListResourceBundle { { "field.zone", "Crios Ama" }, { "islamic.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Domh", - "Luan", - "M\u00e1irt", - "C\u00e9ad", - "D\u00e9ar", - "Aoine", - "Sath", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "D\u00e9 Domhnaigh", - "D\u00e9 Luain", - "D\u00e9 M\u00e1irt", - "D\u00e9 C\u00e9adaoin", - "D\u00e9ardaoin", - "D\u00e9 hAoine", - "D\u00e9 Sathairn", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "C", - "D", - "A", - "S", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "R1", - "R2", - "R3", - "R4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1\u00fa r\u00e1ithe", - "2\u00fa r\u00e1ithe", - "3\u00fa r\u00e1ithe", - "4\u00fa r\u00e1ithe", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "Roimh Chr\u00edost", @@ -243,13 +208,7 @@ public class JavaTimeSupplementary_ga extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "RC", @@ -257,52 +216,15 @@ public class JavaTimeSupplementary_ga extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Domh", - "Luan", - "M\u00e1irt", - "C\u00e9ad", - "D\u00e9ar", - "Aoine", - "Sath", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "D\u00e9 Domhnaigh", - "D\u00e9 Luain", - "D\u00e9 M\u00e1irt", - "D\u00e9 C\u00e9adaoin", - "D\u00e9ardaoin", - "D\u00e9 hAoine", - "D\u00e9 Sathairn", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "C", - "D", - "A", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "Ean", @@ -355,41 +277,13 @@ public class JavaTimeSupplementary_ga extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "R1", - "R2", - "R3", - "R4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1\u00fa r\u00e1ithe", - "2\u00fa r\u00e1ithe", - "3\u00fa r\u00e1ithe", - "4\u00fa r\u00e1ithe", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java index 50eff49e004..65751775f72 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java @@ -72,23 +72,91 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "\u0924\u093f1", + "\u0924\u093f2", + "\u0924\u093f3", + "\u0924\u093f4", + }; + + final String[] sharedQuarterNames = { + "\u092a\u0939\u0932\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", + "\u0926\u0942\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", + "\u0924\u0940\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", + "\u091a\u094c\u0925\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", + }; + + final String[] sharedAmPmMarkers = { + "\u092a\u0942\u0930\u094d\u0935\u093e\u0939\u094d\u0928", + "\u0905\u092a\u0930\u093e\u0939\u094d\u0928", + }; + + final String[] sharedDatePatterns = { + "GGGG EEEE, d MMMM y", + "GGGG d MMMM y", + "GGGG d MMM y", + "GGGG d/M/y", + }; + + final String[] sharedDayAbbreviations = { + "\u0930\u0935\u093f", + "\u0938\u094b\u092e", + "\u092e\u0902\u0917\u0932", + "\u092c\u0941\u0927", + "\u0917\u0941\u0930\u0941", + "\u0936\u0941\u0915\u094d\u0930", + "\u0936\u0928\u093f", + }; + + final String[] sharedDayNames = { + "\u0930\u0935\u093f\u0935\u093e\u0930", + "\u0938\u094b\u092e\u0935\u093e\u0930", + "\u092e\u0902\u0917\u0932\u0935\u093e\u0930", + "\u092c\u0941\u0927\u0935\u093e\u0930", + "\u0917\u0941\u0930\u0941\u0935\u093e\u0930", + "\u0936\u0941\u0915\u094d\u0930\u0935\u093e\u0930", + "\u0936\u0928\u093f\u0935\u093e\u0930", + }; + + final String[] sharedDayNarrows = { + "\u0930", + "\u0938\u094b", + "\u092e\u0902", + "\u092c\u0941", + "\u0917\u0941", + "\u0936\u0941", + "\u0936", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedAbbreviatedAmPmMarkers = { + "\u092a\u0942\u0930\u094d\u0935", + "\u0905\u092a\u0930", + }; + + final String[] sharedNarrowAmPmMarkers = { + "\u092a\u0942", + "\u0905", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G EEEE, d MMMM y", + "G d MMMM y", + "G d MMM y", + "G d/M/y", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u0924\u093f1", - "\u0924\u093f2", - "\u0924\u093f3", - "\u0924\u093f4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\u092a\u0939\u0932\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0926\u0942\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0924\u0940\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u091a\u094c\u0925\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u092c\u094c\u0926\u094d\u0927 \u092a\u0902\u091a\u093e\u0902\u0917" }, { "calendarname.gregorian", @@ -124,52 +192,15 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { { "field.zone", "\u0938\u092e\u092f \u0915\u094d\u0937\u0947\u0924\u094d\u0930" }, { "islamic.AmPmMarkers", - new String[] { - "\u092a\u0942\u0930\u094d\u0935\u093e\u0939\u094d\u0928", - "\u0905\u092a\u0930\u093e\u0939\u094d\u0928", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG EEEE, d MMMM y", - "GGGG d MMMM y", - "GGGG d MMM y", - "GGGG d/M/y", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u0930\u0935\u093f", - "\u0938\u094b\u092e", - "\u092e\u0902\u0917\u0932", - "\u092c\u0941\u0927", - "\u0917\u0941\u0930\u0941", - "\u0936\u0941\u0915\u094d\u0930", - "\u0936\u0928\u093f", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u0930\u0935\u093f\u0935\u093e\u0930", - "\u0938\u094b\u092e\u0935\u093e\u0930", - "\u092e\u0902\u0917\u0932\u0935\u093e\u0930", - "\u092c\u0941\u0927\u0935\u093e\u0930", - "\u0917\u0941\u0930\u0941\u0935\u093e\u0930", - "\u0936\u0941\u0915\u094d\u0930\u0935\u093e\u0930", - "\u0936\u0928\u093f\u0935\u093e\u0930", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u0930", - "\u0938\u094b", - "\u092e\u0902", - "\u092c\u0941", - "\u0917\u0941", - "\u0936\u0941", - "\u0936", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "\u092e\u0941\u0939\u0930\u094d\u0930\u092e", @@ -188,73 +219,21 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "\u0924\u093f1", - "\u0924\u093f2", - "\u0924\u093f3", - "\u0924\u093f4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u092a\u0939\u0932\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0926\u0942\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0924\u0940\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u091a\u094c\u0925\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u092a\u0942\u0930\u094d\u0935", - "\u0905\u092a\u0930", - } - }, + sharedAbbreviatedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u092a\u0942", - "\u0905", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G EEEE, d MMMM y", - "G d MMMM y", - "G d MMM y", - "G d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G EEEE, d MMMM y", - "G d MMMM y", - "G d MMM y", - "G d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "G EEEE, d MMMM y", - "G d MMMM y", - "G d MMM y", - "G d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", new String[] { "\u0908\u0938\u0935\u0940 \u0938\u0928", @@ -280,13 +259,7 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G EEEE, d MMMM y", - "G d MMMM y", - "G d MMM y", - "G d/M/y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u0908\u0938\u093e\u092a\u0942\u0930\u094d\u0935", @@ -294,52 +267,15 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u092a\u0942\u0930\u094d\u0935\u093e\u0939\u094d\u0928", - "\u0905\u092a\u0930\u093e\u0939\u094d\u0928", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG EEEE, d MMMM y", - "GGGG d MMMM y", - "GGGG d MMM y", - "GGGG d/M/y", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u0930\u0935\u093f", - "\u0938\u094b\u092e", - "\u092e\u0902\u0917\u0932", - "\u092c\u0941\u0927", - "\u0917\u0941\u0930\u0941", - "\u0936\u0941\u0915\u094d\u0930", - "\u0936\u0928\u093f", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u0930\u0935\u093f\u0935\u093e\u0930", - "\u0938\u094b\u092e\u0935\u093e\u0930", - "\u092e\u0902\u0917\u0932\u0935\u093e\u0930", - "\u092c\u0941\u0927\u0935\u093e\u0930", - "\u0917\u0941\u0930\u0941\u0935\u093e\u0930", - "\u0936\u0941\u0915\u094d\u0930\u0935\u093e\u0930", - "\u0936\u0928\u093f\u0935\u093e\u0930", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u0930", - "\u0938\u094b", - "\u092e\u0902", - "\u092c\u0941", - "\u0917\u0941", - "\u0936\u0941", - "\u0936", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u091c\u0928\u0970", @@ -392,41 +328,15 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u0924\u093f1", - "\u0924\u093f2", - "\u0924\u093f3", - "\u0924\u093f4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u092a\u0939\u0932\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0926\u0942\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u0924\u0940\u0938\u0930\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - "\u091a\u094c\u0925\u0940 \u0924\u093f\u092e\u093e\u0939\u0940", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u092a\u0942\u0930\u094d\u0935", - "\u0905\u092a\u0930", - } - }, + sharedAbbreviatedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u092a\u0942", - "\u0905", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java index e9531142fa7..b8bb2b1ef08 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java @@ -72,31 +72,88 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_hr extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1kv", + "2kv", + "3kv", + "4kv", + }; + + final String[] sharedQuarterNames = { + "1. kvartal", + "2. kvartal", + "3. kvartal", + "4. kvartal", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedDayAbbreviations = { + "ned", + "pon", + "uto", + "sri", + "\u010det", + "pet", + "sub", + }; + + final String[] sharedDayNames = { + "nedjelja", + "ponedjeljak", + "utorak", + "srijeda", + "\u010detvrtak", + "petak", + "subota", + }; + + final String[] sharedDayNarrows = { + "N", + "P", + "U", + "S", + "\u010c", + "P", + "S", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d. MMMM y. G", + "d. MMMM y. G", + "d. MMM y. G", + "dd.MM.y. GGGGG", + }; + + final String[] sharedJavaTimeDatePatterns2 = { + "EEEE, d. MMMM y. G", + "d. MMMM y. G", + "d. M. y. G", + "d.M.y. GGGGG", + }; + + final String[] sharedEras = { + "prije R.O.C.", + "R.O.C.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1kv", - "2kv", - "3kv", - "4kv", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "budisti\u010dki kalendar" }, { "calendarname.gregorian", @@ -132,11 +189,7 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { { "field.zone", "vremenska zona" }, { "islamic.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE, d. MMMM y. GGGG", @@ -146,114 +199,21 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "ned", - "pon", - "uto", - "sri", - "\u010det", - "pet", - "sub", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "nedjelja", - "ponedjeljak", - "utorak", - "srijeda", - "\u010detvrtak", - "petak", - "subota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "N", - "P", - "U", - "S", - "\u010c", - "P", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1kv", - "2kv", - "3kv", - "4kv", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedQuarterNarrows }, { "islamic.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d. MMMM y. G", - "d. MMMM y. G", - "d. MMM y. G", - "dd.MM.y. GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -261,21 +221,9 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y. G", - "d. MMMM y. G", - "d. M. y. G", - "d.M.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns2 }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d. MMMM y. G", - "d. MMMM y. G", - "d. M. y. G", - "d.M.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns2 }, { "java.time.japanese.long.Eras", new String[] { "poslije Krista", @@ -301,25 +249,13 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y. G", - "d. MMMM y. G", - "d. MMM y. G", - "dd.MM.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "Prije Krista", "Poslije Krista", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", new String[] { "EEEE, d. MMMM y. GGGG", @@ -329,44 +265,13 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "ned", - "pon", - "uto", - "sri", - "\u010det", - "pet", - "sub", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "nedjelja", - "ponedjeljak", - "utorak", - "srijeda", - "\u010detvrtak", - "petak", - "subota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "N", - "P", - "U", - "S", - "\u010c", - "P", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "prije R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "sij", @@ -419,61 +324,17 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1kv", - "2kv", - "3kv", - "4kv", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNarrows }, { "roc.long.Eras", - new String[] { - "prije R.O.C.", - "R.O.C.", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedEras }, { "roc.narrow.Eras", - new String[] { - "prije R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "prije R.O.C.", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hu.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hu.java index 18c629c4f7c..30c32652c7f 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hu.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hu.java @@ -72,35 +72,105 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_hu extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimebuddhistlongEras = { + final String[] sharedQuarterAbbreviations = { + "N1", + "N2", + "N3", + "N4", + }; + + final String[] sharedQuarterNames = { + "I. negyed\u00e9v", + "II. negyed\u00e9v", + "III. negyed\u00e9v", + "IV. negyed\u00e9v", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "de.", + "du.", + }; + + final String[] sharedDatePatterns = { + "GGGG y. MMMM d., EEEE", + "GGGG y. MMMM d.", + "GGGG y. MMM d.", + "G y. M. d.", + }; + + final String[] sharedDayAbbreviations = { + "V", + "H", + "K", + "Sze", + "Cs", + "P", + "Szo", + }; + + final String[] sharedDayNames = { + "vas\u00e1rnap", + "h\u00e9tf\u0151", + "kedd", + "szerda", + "cs\u00fct\u00f6rt\u00f6k", + "p\u00e9ntek", + "szombat", + }; + + final String[] sharedDayNarrows = { + "V", + "H", + "K", + "Sz", + "Cs", + "P", + "Sz", + }; + + final String[] sharedEras = { + "", + "MF", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y. MMMM d., EEEE", + "G y. MMMM d.", + "G y. MMM d.", + "GGGGG y. M. d.", + }; + + final String[] sharedJavaTimeLongEras = { "BC", "BK", }; + + final String[] sharedShortEras = { + "R.O.C. el\u0151tt", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "N1", - "N2", - "N3", - "N4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "I. negyed\u00e9v", - "II. negyed\u00e9v", - "III. negyed\u00e9v", - "IV. negyed\u00e9v", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "Buddhista napt\u00e1r" }, { "calendarname.gregorian", @@ -136,58 +206,17 @@ public class JavaTimeSupplementary_hu extends OpenListResourceBundle { { "field.zone", "id\u0151z\u00f3na" }, { "islamic.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y. MMMM d., EEEE", - "GGGG y. MMMM d.", - "GGGG y. MMM d.", - "G y. M. d.", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "V", - "H", - "K", - "Sze", - "Cs", - "P", - "Szo", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "vas\u00e1rnap", - "h\u00e9tf\u0151", - "kedd", - "szerda", - "cs\u00fct\u00f6rt\u00f6k", - "p\u00e9ntek", - "szombat", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "V", - "H", - "K", - "Sz", - "Cs", - "P", - "Sz", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "MF", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", new String[] { "Moh.", @@ -223,87 +252,31 @@ public class JavaTimeSupplementary_hu extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "N1", - "N2", - "N3", - "N4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "I. negyed\u00e9v", - "II. negyed\u00e9v", - "III. negyed\u00e9v", - "IV. negyed\u00e9v", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "MF", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "MF", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "MF", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y. MMMM d., EEEE", - "G y. MMMM d.", - "G y. MMM d.", - "GGGGG y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "G y. MMMM d., EEEE", - "G y. MMMM d.", - "G y. MMM d.", - "GGGGG y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "G y. MMMM d., EEEE", @@ -319,13 +292,7 @@ public class JavaTimeSupplementary_hu extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y. MMMM d., EEEE", - "G y. MMMM d.", - "G y. MMM d.", - "GGGGG y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "i.e.", @@ -333,58 +300,17 @@ public class JavaTimeSupplementary_hu extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y. MMMM d., EEEE", - "GGGG y. MMMM d.", - "GGGG y. MMM d.", - "G y. M. d.", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "V", - "H", - "K", - "Sze", - "Cs", - "P", - "Szo", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "vas\u00e1rnap", - "h\u00e9tf\u0151", - "kedd", - "szerda", - "cs\u00fct\u00f6rt\u00f6k", - "p\u00e9ntek", - "szombat", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "V", - "H", - "K", - "Sz", - "Cs", - "P", - "Sz", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "R.O.C. el\u0151tt", - "", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -437,67 +363,23 @@ public class JavaTimeSupplementary_hu extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "N1", - "N2", - "N3", - "N4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "I. negyed\u00e9v", - "II. negyed\u00e9v", - "III. negyed\u00e9v", - "IV. negyed\u00e9v", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "R.O.C. el\u0151tt", - "", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "de.", - "du.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "R.O.C. el\u0151tt", - "", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "R.O.C. el\u0151tt", - "", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java index 3325f5e8cb9..dcb2c112372 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java @@ -72,23 +72,94 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_in extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "Kuartal ke-1", + "Kuartal ke-2", + "Kuartal ke-3", + "Kuartal ke-4", + }; + + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedDatePatterns = { + "EEEE, dd MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "d/M/y G", + }; + + final String[] sharedDayAbbreviations = { + "Min", + "Sen", + "Sel", + "Rab", + "Kam", + "Jum", + "Sab", + }; + + final String[] sharedDayNames = { + "Minggu", + "Senin", + "Selasa", + "Rabu", + "Kamis", + "Jumat", + "Sabtu", + }; + + final String[] sharedDayNarrows = { + "M", + "S", + "S", + "R", + "K", + "J", + "S", + }; + + final String[] sharedTimePatterns = { + "HH.mm.ss zzzz", + "HH.mm.ss z", + "HH.mm.ss", + "HH.mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, dd MMMM y G", + "d MMMM y G", + "d MMM y G", + "d/M/y GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { + "M", + "Meiji", + "Taish\u014d", + "Sh\u014dwa", + "Heisei", + }; + + final String[] sharedEras = { + "Sebelum R.O.C.", + "R.O.C.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "Kuartal ke-1", - "Kuartal ke-2", - "Kuartal ke-3", - "Kuartal ke-4", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Kalender Buddha" }, { "calendarname.gregorian", @@ -122,58 +193,15 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { { "field.zone", "Zona Waktu" }, { "islamic.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/M/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Min", - "Sen", - "Sel", - "Rab", - "Kam", - "Jum", - "Sab", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Minggu", - "Senin", - "Selasa", - "Rabu", - "Kamis", - "Jumat", - "Sabtu", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "M", - "S", - "S", - "R", - "K", - "J", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", new String[] { "Muh.", @@ -209,75 +237,15 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "Kuartal ke-1", - "Kuartal ke-2", - "Kuartal ke-3", - "Kuartal ke-4", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -285,39 +253,13 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", - new String[] { - "M", - "Meiji", - "Taish\u014d", - "Sh\u014dwa", - "Heisei", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.short.Eras", - new String[] { - "M", - "Meiji", - "Taish\u014d", - "Sh\u014dwa", - "Heisei", - } - }, + sharedJavaTimeLongEras }, { "java.time.long.Eras", new String[] { "Sebelum Masehi", @@ -325,72 +267,23 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/M/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "BCE", "CE", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/M/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Min", - "Sen", - "Sel", - "Rab", - "Kam", - "Jum", - "Sab", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Minggu", - "Senin", - "Selasa", - "Rabu", - "Kamis", - "Jumat", - "Sabtu", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "M", - "S", - "S", - "R", - "K", - "J", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Sebelum R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "Jan", @@ -443,53 +336,17 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "Kuartal ke-1", - "Kuartal ke-2", - "Kuartal ke-3", - "Kuartal ke-4", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "roc.long.Eras", - new String[] { - "Sebelum R.O.C.", - "R.O.C.", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedEras }, { "roc.narrow.Eras", - new String[] { - "Sebelum R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Sebelum R.O.C.", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_is.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_is.java index 7cf4a8bf1a4..b2760c21e50 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_is.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_is.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_is extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "F1", + "F2", + "F3", + "F4", + }; + + final String[] sharedQuarterNames = { + "1. fj\u00f3r\u00f0ungur", + "2. fj\u00f3r\u00f0ungur", + "3. fj\u00f3r\u00f0ungur", + "4. fj\u00f3r\u00f0ungur", + }; + + final String[] sharedAmPmMarkers = { + "f.h.", + "e.h.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d. MMMM y GGGG", + "d. MMMM y GGGG", + "d.M.y GGGG", + "d.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "sun.", + "m\u00e1n.", + "\u00feri.", + "mi\u00f0.", + "fim.", + "f\u00f6s.", + "lau.", + }; + + final String[] sharedDayNames = { + "sunnudagur", + "m\u00e1nudagur", + "\u00feri\u00f0judagur", + "mi\u00f0vikudagur", + "fimmtudagur", + "f\u00f6studagur", + "laugardagur", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "\u00de", + "M", + "F", + "F", + "L", + }; + + final String[] sharedNarrowAmPmMarkers = { + "f.", + "e.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d. MMMM y G", + "d. MMMM y G", + "d.M.y G", + "d.M.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "F1", - "F2", - "F3", - "F4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. fj\u00f3r\u00f0ungur", - "2. fj\u00f3r\u00f0ungur", - "3. fj\u00f3r\u00f0ungur", - "4. fj\u00f3r\u00f0ungur", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "B\u00fadd\u00edskt dagatal" }, { "calendarname.gregorian", @@ -124,120 +180,29 @@ public class JavaTimeSupplementary_is extends OpenListResourceBundle { { "field.zone", "t\u00edmabelti" }, { "islamic.AmPmMarkers", - new String[] { - "f.h.", - "e.h.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "sun.", - "m\u00e1n.", - "\u00feri.", - "mi\u00f0.", - "fim.", - "f\u00f6s.", - "lau.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "sunnudagur", - "m\u00e1nudagur", - "\u00feri\u00f0judagur", - "mi\u00f0vikudagur", - "fimmtudagur", - "f\u00f6studagur", - "laugardagur", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "\u00de", - "M", - "F", - "F", - "L", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "F1", - "F2", - "F3", - "F4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. fj\u00f3r\u00f0ungur", - "2. fj\u00f3r\u00f0ungur", - "3. fj\u00f3r\u00f0ungur", - "4. fj\u00f3r\u00f0ungur", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "f.h.", - "e.h.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "f.", - "e.", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "fyrir Krist", @@ -245,13 +210,7 @@ public class JavaTimeSupplementary_is extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y G", - "d. MMMM y G", - "d.M.y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "f.Kr.", @@ -259,52 +218,15 @@ public class JavaTimeSupplementary_is extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "f.h.", - "e.h.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d. MMMM y GGGG", - "d. MMMM y GGGG", - "d.M.y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "sun.", - "m\u00e1n.", - "\u00feri.", - "mi\u00f0.", - "fim.", - "f\u00f6s.", - "lau.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "sunnudagur", - "m\u00e1nudagur", - "\u00feri\u00f0judagur", - "mi\u00f0vikudagur", - "fimmtudagur", - "f\u00f6studagur", - "laugardagur", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "\u00de", - "M", - "F", - "F", - "L", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -357,41 +279,13 @@ public class JavaTimeSupplementary_is extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "F1", - "F2", - "F3", - "F4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. fj\u00f3r\u00f0ungur", - "2. fj\u00f3r\u00f0ungur", - "3. fj\u00f3r\u00f0ungur", - "4. fj\u00f3r\u00f0ungur", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "f.h.", - "e.h.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "f.", - "e.", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it.java index 3a3d52e7747..d664f5cb3af 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it.java @@ -72,23 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_it extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "T1", + "T2", + "T3", + "T4", + }; + + final String[] sharedQuarterNames = { + "1\u00ba trimestre", + "2\u00ba trimestre", + "3\u00ba trimestre", + "4\u00ba trimestre", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "dd MMMM y GGGG", + "dd MMM y GGGG", + "dd/MM/yy G", + }; + + final String[] sharedDayAbbreviations = { + "dom", + "lun", + "mar", + "mer", + "gio", + "ven", + "sab", + }; + + final String[] sharedDayNames = { + "domenica", + "luned\u00ec", + "marted\u00ec", + "mercoled\u00ec", + "gioved\u00ec", + "venerd\u00ec", + "sabato", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "M", + "G", + "V", + "S", + }; + + final String[] sharedNarrowAmPmMarkers = { + "m.", + "p.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "dd MMMM y G", + "dd MMM y G", + "dd/MM/yy GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { + "BC", + "EB", + }; + + final String[] sharedEras = { + "Prima di R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Calendario buddista" }, { "calendarname.gregorian", @@ -132,144 +193,29 @@ public class JavaTimeSupplementary_it extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "dd/MM/yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "dom", - "lun", - "mar", - "mer", - "gio", - "ven", - "sab", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "domenica", - "luned\u00ec", - "marted\u00ec", - "mercoled\u00ec", - "gioved\u00ec", - "venerd\u00ec", - "sabato", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "G", - "V", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedQuarterNames }, { "islamic.narrow.AmPmMarkers", - new String[] { - "m.", - "p.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "EB", - } - }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - new String[] { - "BC", - "EB", - } - }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "a.C.", @@ -277,72 +223,23 @@ public class JavaTimeSupplementary_it extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "dd MMMM y G", - "dd MMM y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "BC", "dopo Cristo", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "dd MMMM y GGGG", - "dd MMM y GGGG", - "dd/MM/yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "dom", - "lun", - "mar", - "mer", - "gio", - "ven", - "sab", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "domenica", - "luned\u00ec", - "marted\u00ec", - "mercoled\u00ec", - "gioved\u00ec", - "venerd\u00ec", - "sabato", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "G", - "V", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Prima di R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "gen", @@ -395,53 +292,17 @@ public class JavaTimeSupplementary_it extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.long.Eras", - new String[] { - "Prima di R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "m.", - "p.", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Prima di R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Prima di R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it_CH.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it_CH.java index 96f1bb420ab..68ceaa0ab91 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it_CH.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_it_CH.java @@ -72,55 +72,33 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_it_CH extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd.MM.yy G", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd.MM.yy GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_iw.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_iw.java index e933a2015c6..76e9c8ee1a2 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_iw.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_iw.java @@ -72,23 +72,72 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_iw extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "\u05e8\u05d1\u05e2\u05d5\u05df 1", + "\u05e8\u05d1\u05e2\u05d5\u05df 2", + "\u05e8\u05d1\u05e2\u05d5\u05df 3", + "\u05e8\u05d1\u05e2\u05d5\u05df 4", + }; + + final String[] sharedAmPmMarkers = { + "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", + "\u05d0\u05d7\u05d4\u05f4\u05e6", + }; + + final String[] sharedDayAbbreviations = { + "\u05d9\u05d5\u05dd \u05d0\u05f3", + "\u05d9\u05d5\u05dd \u05d1\u05f3", + "\u05d9\u05d5\u05dd \u05d2\u05f3", + "\u05d9\u05d5\u05dd \u05d3\u05f3", + "\u05d9\u05d5\u05dd \u05d4\u05f3", + "\u05d9\u05d5\u05dd \u05d5\u05f3", + "\u05e9\u05d1\u05ea", + }; + + final String[] sharedDayNames = { + "\u05d9\u05d5\u05dd \u05e8\u05d0\u05e9\u05d5\u05df", + "\u05d9\u05d5\u05dd \u05e9\u05e0\u05d9", + "\u05d9\u05d5\u05dd \u05e9\u05dc\u05d9\u05e9\u05d9", + "\u05d9\u05d5\u05dd \u05e8\u05d1\u05d9\u05e2\u05d9", + "\u05d9\u05d5\u05dd \u05d7\u05de\u05d9\u05e9\u05d9", + "\u05d9\u05d5\u05dd \u05e9\u05d9\u05e9\u05d9", + "\u05d9\u05d5\u05dd \u05e9\u05d1\u05ea", + }; + + final String[] sharedDayNarrows = { + "\u05d0\u05f3", + "\u05d1\u05f3", + "\u05d2\u05f3", + "\u05d3\u05f3", + "\u05d4\u05f3", + "\u05d5\u05f3", + "\u05e9\u05f3", + }; + + final String[] sharedEras = { + "", + "\u05e9\u05e0\u05ea \u05d4\u05d9\u05d2\u05f3\u05e8\u05d4", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d \u05d1MMMM y G", + "d \u05d1MMMM y G", + "d \u05d1MMM y G", + "d.M.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u05dc\u05d5\u05d7 \u05e9\u05e0\u05d4 \u05d1\u05d5\u05d3\u05d4\u05d9\u05e1\u05d8\u05d9" }, { "calendarname.gregorian", @@ -124,11 +173,7 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { { "field.zone", "\u05d0\u05d6\u05d5\u05e8" }, { "islamic.AmPmMarkers", - new String[] { - "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", - "\u05d0\u05d7\u05d4\u05f4\u05e6", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE, d \u05d1MMMM y GGGG", @@ -138,44 +183,13 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "\u05d9\u05d5\u05dd \u05d0\u05f3", - "\u05d9\u05d5\u05dd \u05d1\u05f3", - "\u05d9\u05d5\u05dd \u05d2\u05f3", - "\u05d9\u05d5\u05dd \u05d3\u05f3", - "\u05d9\u05d5\u05dd \u05d4\u05f3", - "\u05d9\u05d5\u05dd \u05d5\u05f3", - "\u05e9\u05d1\u05ea", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u05d9\u05d5\u05dd \u05e8\u05d0\u05e9\u05d5\u05df", - "\u05d9\u05d5\u05dd \u05e9\u05e0\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05dc\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e8\u05d1\u05d9\u05e2\u05d9", - "\u05d9\u05d5\u05dd \u05d7\u05de\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05d1\u05ea", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u05d0\u05f3", - "\u05d1\u05f3", - "\u05d2\u05f3", - "\u05d3\u05f3", - "\u05d4\u05f3", - "\u05d5\u05f3", - "\u05e9\u05f3", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "\u05e9\u05e0\u05ea \u05d4\u05d9\u05d2\u05f3\u05e8\u05d4", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", new String[] { "\u05de\u05d5\u05d7\u05e8\u05dd", @@ -211,69 +225,21 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, + sharedQuarterNames }, { "islamic.QuarterNames", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", - "\u05d0\u05d7\u05d4\u05f4\u05e6", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "\u05e9\u05e0\u05ea \u05d4\u05d9\u05d2\u05f3\u05e8\u05d4", - } - }, + sharedEras }, { "islamic.narrow.Eras", - new String[] { - "", - "\u05e9\u05e0\u05ea \u05d4\u05d9\u05d2\u05f3\u05e8\u05d4", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u05e9\u05e0\u05ea \u05d4\u05d9\u05d2\u05f3\u05e8\u05d4", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d \u05d1MMMM y G", - "d \u05d1MMMM y G", - "d \u05d1MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", new String[] { "EEEE, d \u05d1MMMM y G", @@ -283,13 +249,7 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d \u05d1MMMM y G", - "d \u05d1MMMM y G", - "d \u05d1MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u05dc\u05e4\u05e0\u05d9 \u05d4\u05e1\u05e4\u05d9\u05e8\u05d4", @@ -297,13 +257,7 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d \u05d1MMMM y G", - "d \u05d1MMMM y G", - "d \u05d1MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u05dc\u05e1\u05d4\"\u05e0", @@ -311,11 +265,7 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", - "\u05d0\u05d7\u05d4\u05f4\u05e6", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "EEEE, d \u05d1MMMM y GGGG", @@ -325,38 +275,11 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "\u05d9\u05d5\u05dd \u05d0\u05f3", - "\u05d9\u05d5\u05dd \u05d1\u05f3", - "\u05d9\u05d5\u05dd \u05d2\u05f3", - "\u05d9\u05d5\u05dd \u05d3\u05f3", - "\u05d9\u05d5\u05dd \u05d4\u05f3", - "\u05d9\u05d5\u05dd \u05d5\u05f3", - "\u05e9\u05d1\u05ea", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u05d9\u05d5\u05dd \u05e8\u05d0\u05e9\u05d5\u05df", - "\u05d9\u05d5\u05dd \u05e9\u05e0\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05dc\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e8\u05d1\u05d9\u05e2\u05d9", - "\u05d9\u05d5\u05dd \u05d7\u05de\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05d9\u05e9\u05d9", - "\u05d9\u05d5\u05dd \u05e9\u05d1\u05ea", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u05d0\u05f3", - "\u05d1\u05f3", - "\u05d2\u05f3", - "\u05d3\u05f3", - "\u05d4\u05f3", - "\u05d5\u05f3", - "\u05e9\u05f3", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u05d9\u05e0\u05d5\u05f3", @@ -391,59 +314,16 @@ public class JavaTimeSupplementary_iw extends OpenListResourceBundle { "", } }, - { "roc.MonthNarrows", - new String[] { - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "", - } - }, { "roc.QuarterAbbreviations", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, + sharedQuarterNames }, { "roc.QuarterNames", - new String[] { - "\u05e8\u05d1\u05e2\u05d5\u05df 1", - "\u05e8\u05d1\u05e2\u05d5\u05df 2", - "\u05e8\u05d1\u05e2\u05d5\u05df 3", - "\u05e8\u05d1\u05e2\u05d5\u05df 4", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", - "\u05d0\u05d7\u05d4\u05f4\u05e6", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u05dc\u05e4\u05e0\u05d4\u05f4\u05e6", - "\u05d0\u05d7\u05d4\u05f4\u05e6", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ja.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ja.java index 82778f5e75e..5c4b510140c 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ja.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ja.java @@ -72,19 +72,119 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ja extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterNames = { + "\u7b2c1\u56db\u534a\u671f", + "\u7b2c2\u56db\u534a\u671f", + "\u7b2c3\u56db\u534a\u671f", + "\u7b2c4\u56db\u534a\u671f", + }; + + final String[] sharedAmPmMarkers = { + "\u5348\u524d", + "\u5348\u5f8c", + }; + + final String[] sharedDatePatterns = { + "GGGGy\u5e74M\u6708d\u65e5EEEE", + "GGGGy\u5e74M\u6708d\u65e5", + "GGGGy/MM/dd", + "GGGGy/MM/dd", + }; + + final String[] sharedDayNarrows = { + "\u65e5", + "\u6708", + "\u706b", + "\u6c34", + "\u6728", + "\u91d1", + "\u571f", + }; + + final String[] sharedDayNames = { + "\u65e5\u66dc\u65e5", + "\u6708\u66dc\u65e5", + "\u706b\u66dc\u65e5", + "\u6c34\u66dc\u65e5", + "\u6728\u66dc\u65e5", + "\u91d1\u66dc\u65e5", + "\u571f\u66dc\u65e5", + }; + + final String[] sharedMonthNames = { + "\u30e0\u30cf\u30c3\u30e9\u30e0", + "\u30b5\u30d5\u30a2\u30eb", + "\u30e9\u30d3\u30fc\u30fb\u30a6\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", + "\u30e9\u30d3\u30fc\u30fb\u30a6\u30c3\u30fb\u30b5\u30fc\u30cb\u30fc", + "\u30b8\u30e5\u30de\u30fc\u30c0\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", + "\u30b8\u30e5\u30de\u30fc\u30c0\u30c3\u30b5\u30fc\u30cb\u30fc", + "\u30e9\u30b8\u30e3\u30d6", + "\u30b7\u30e3\u30a2\u30d0\u30fc\u30f3", + "\u30e9\u30de\u30c0\u30fc\u30f3", + "\u30b7\u30e3\u30a6\u30ef\u30fc\u30eb", + "\u30ba\u30eb\u30fb\u30ab\u30a4\u30c0", + "\u30ba\u30eb\u30fb\u30d2\u30c3\u30b8\u30e3", + "", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedTimePatterns = { + "H\u6642mm\u5206ss\u79d2 zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "Gy\u5e74M\u6708d\u65e5EEEE", + "Gy\u5e74M\u6708d\u65e5", + "Gy/MM/dd", + "Gy/MM/dd", + }; + + final String[] sharedJavaTimeLongEras = { + "\u897f\u66a6", + "\u660e\u6cbb", + "\u5927\u6b63", + "\u662d\u548c", + "\u5e73\u6210", + }; + + final String[] sharedJavaTimeShortEras = { "\u7d00\u5143\u524d", "\u897f\u66a6", }; + + final String[] sharedEras = { + "\u6c11\u56fd\u524d", + "\u6c11\u56fd", + }; + + final String[] sharedMonthAbbreviations = { + "1\u6708", + "2\u6708", + "3\u6708", + "4\u6708", + "5\u6708", + "6\u6708", + "7\u6708", + "8\u6708", + "9\u6708", + "10\u6708", + "11\u6708", + "12\u6708", + "", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "\u7b2c1\u56db\u534a\u671f", - "\u7b2c2\u56db\u534a\u671f", - "\u7b2c3\u56db\u534a\u671f", - "\u7b2c4\u56db\u534a\u671f", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u30bf\u30a4\u4ecf\u6559\u66a6" }, { "calendarname.gregorian", @@ -122,154 +222,29 @@ public class JavaTimeSupplementary_ja extends OpenListResourceBundle { { "field.zone", "\u30bf\u30a4\u30e0\u30be\u30fc\u30f3" }, { "islamic.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGGy\u5e74M\u6708d\u65e5EEEE", - "GGGGy\u5e74M\u6708d\u65e5", - "GGGGy/MM/dd", - "GGGGy/MM/dd", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u65e5", - "\u6708", - "\u706b", - "\u6c34", - "\u6728", - "\u91d1", - "\u571f", - } - }, + sharedDayNarrows }, { "islamic.DayNames", - new String[] { - "\u65e5\u66dc\u65e5", - "\u6708\u66dc\u65e5", - "\u706b\u66dc\u65e5", - "\u6c34\u66dc\u65e5", - "\u6728\u66dc\u65e5", - "\u91d1\u66dc\u65e5", - "\u571f\u66dc\u65e5", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u65e5", - "\u6708", - "\u706b", - "\u6c34", - "\u6728", - "\u91d1", - "\u571f", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", - new String[] { - "\u30e0\u30cf\u30c3\u30e9\u30e0", - "\u30b5\u30d5\u30a2\u30eb", - "\u30e9\u30d3\u30fc\u30fb\u30a6\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", - "\u30e9\u30d3\u30fc\u30fb\u30a6\u30c3\u30fb\u30b5\u30fc\u30cb\u30fc", - "\u30b8\u30e5\u30de\u30fc\u30c0\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", - "\u30b8\u30e5\u30de\u30fc\u30c0\u30c3\u30b5\u30fc\u30cb\u30fc", - "\u30e9\u30b8\u30e3\u30d6", - "\u30b7\u30e3\u30a2\u30d0\u30fc\u30f3", - "\u30e9\u30de\u30c0\u30fc\u30f3", - "\u30b7\u30e3\u30a6\u30ef\u30fc\u30eb", - "\u30ba\u30eb\u30fb\u30ab\u30a4\u30c0", - "\u30ba\u30eb\u30fb\u30d2\u30c3\u30b8\u30e3", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNames", - new String[] { - "\u30e0\u30cf\u30c3\u30e9\u30e0", - "\u30b5\u30d5\u30a2\u30eb", - "\u30e9\u30d3\u30fc\u30fb\u30a6\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", - "\u30e9\u30d3\u30fc\u30fb\u30a6\u30c3\u30fb\u30b5\u30fc\u30cb\u30fc", - "\u30b8\u30e5\u30de\u30fc\u30c0\u30eb\u30fb\u30a2\u30a6\u30ef\u30eb", - "\u30b8\u30e5\u30de\u30fc\u30c0\u30c3\u30b5\u30fc\u30cb\u30fc", - "\u30e9\u30b8\u30e3\u30d6", - "\u30b7\u30e3\u30a2\u30d0\u30fc\u30f3", - "\u30e9\u30de\u30c0\u30fc\u30f3", - "\u30b7\u30e3\u30a6\u30ef\u30fc\u30eb", - "\u30ba\u30eb\u30fb\u30ab\u30a4\u30c0", - "\u30ba\u30eb\u30fb\u30d2\u30c3\u30b8\u30e3", - "", - } - }, + sharedMonthNames }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u7b2c1\u56db\u534a\u671f", - "\u7b2c2\u56db\u534a\u671f", - "\u7b2c3\u56db\u534a\u671f", - "\u7b2c4\u56db\u534a\u671f", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H\u6642mm\u5206ss\u79d2 zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", new String[] { "GGGGy\u5e74M\u6708d\u65e5EEEE", @@ -291,13 +266,7 @@ public class JavaTimeSupplementary_ja extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "Gy\u5e74M\u6708d\u65e5EEEE", - "Gy\u5e74M\u6708d\u65e5", - "Gy/MM/dd", - "Gy/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "Gy'\u5e74'M'\u6708'd'\u65e5'", @@ -307,193 +276,47 @@ public class JavaTimeSupplementary_ja extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "\u897f\u66a6", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.short.Eras", - new String[] { - "\u897f\u66a6", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeLongEras }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeShortEras }, { "java.time.roc.DatePatterns", - new String[] { - "Gy\u5e74M\u6708d\u65e5EEEE", - "Gy\u5e74M\u6708d\u65e5", - "Gy/MM/dd", - "Gy/MM/dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeShortEras }, { "roc.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGGy\u5e74M\u6708d\u65e5EEEE", - "GGGGy\u5e74M\u6708d\u65e5", - "GGGGy/MM/dd", - "GGGGy/MM/dd", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u65e5", - "\u6708", - "\u706b", - "\u6c34", - "\u6728", - "\u91d1", - "\u571f", - } - }, + sharedDayNarrows }, { "roc.DayNames", - new String[] { - "\u65e5\u66dc\u65e5", - "\u6708\u66dc\u65e5", - "\u706b\u66dc\u65e5", - "\u6c34\u66dc\u65e5", - "\u6728\u66dc\u65e5", - "\u91d1\u66dc\u65e5", - "\u571f\u66dc\u65e5", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u65e5", - "\u6708", - "\u706b", - "\u6c34", - "\u6728", - "\u91d1", - "\u571f", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedEras }, { "roc.MonthAbbreviations", - new String[] { - "1\u6708", - "2\u6708", - "3\u6708", - "4\u6708", - "5\u6708", - "6\u6708", - "7\u6708", - "8\u6708", - "9\u6708", - "10\u6708", - "11\u6708", - "12\u6708", - "", - } - }, + sharedMonthAbbreviations }, { "roc.MonthNames", - new String[] { - "1\u6708", - "2\u6708", - "3\u6708", - "4\u6708", - "5\u6708", - "6\u6708", - "7\u6708", - "8\u6708", - "9\u6708", - "10\u6708", - "11\u6708", - "12\u6708", - "", - } - }, - { "roc.MonthNarrows", - new String[] { - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "", - } - }, + sharedMonthAbbreviations }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u7b2c1\u56db\u534a\u671f", - "\u7b2c2\u56db\u534a\u671f", - "\u7b2c3\u56db\u534a\u671f", - "\u7b2c4\u56db\u534a\u671f", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H\u6642mm\u5206ss\u79d2 zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u5348\u524d", - "\u5348\u5f8c", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java index 4257fba3582..0349aed4af4 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java @@ -72,31 +72,110 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ko extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimebuddhistlongEras = { + final String[] sharedQuarterAbbreviations = { + "1\ubd84\uae30", + "2\ubd84\uae30", + "3\ubd84\uae30", + "4\ubd84\uae30", + }; + + final String[] sharedQuarterNames = { + "\uc81c 1/4\ubd84\uae30", + "\uc81c 2/4\ubd84\uae30", + "\uc81c 3/4\ubd84\uae30", + "\uc81c 4/4\ubd84\uae30", + }; + + final String[] sharedAmPmMarkers = { + "\uc624\uc804", + "\uc624\ud6c4", + }; + + final String[] sharedDatePatterns = { + "GGGG y\ub144 M\uc6d4 d\uc77c EEEE", + "GGGG y\ub144 M\uc6d4 d\uc77c", + "GGGG y. M. d.", + "GGGG y. M. d.", + }; + + final String[] sharedDayNarrows = { + "\uc77c", + "\uc6d4", + "\ud654", + "\uc218", + "\ubaa9", + "\uae08", + "\ud1a0", + }; + + final String[] sharedDayNames = { + "\uc77c\uc694\uc77c", + "\uc6d4\uc694\uc77c", + "\ud654\uc694\uc77c", + "\uc218\uc694\uc77c", + "\ubaa9\uc694\uc77c", + "\uae08\uc694\uc77c", + "\ud1a0\uc694\uc77c", + }; + + final String[] sharedTimePatterns = { + "a h\uc2dc m\ubd84 s\ucd08 zzzz", + "a h\uc2dc m\ubd84 s\ucd08 z", + "a h:mm:ss", + "a h:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y\ub144 M\uc6d4 d\uc77c EEEE", + "G y\ub144 M\uc6d4 d\uc77c", + "G y. M. d.", + "G y. M. d.", + }; + + final String[] sharedJavaTimeLongEras = { "BC", "\ubd88\uae30", }; - final String[] javatimelongEras = { + + final String[] sharedJavaTimeShortEras = { + "\uc11c\uae30", + "\uba54\uc774\uc9c0", + "\ub2e4\uc774\uc1fc", + "\uc1fc\uc640", + "\ud5e4\uc774\uc138\uc774", + }; + + final String[] sharedJavaTimeShortEras2 = { "\uae30\uc6d0\uc804", "\uc11c\uae30", }; + + final String[] sharedEras = { + "\uc911\ud654\ubbfc\uad6d\uc804", + "\uc911\ud654\ubbfc\uad6d", + }; + + final String[] sharedMonthNames = { + "1\uc6d4", + "2\uc6d4", + "3\uc6d4", + "4\uc6d4", + "5\uc6d4", + "6\uc6d4", + "7\uc6d4", + "8\uc6d4", + "9\uc6d4", + "10\uc6d4", + "11\uc6d4", + "12\uc6d4", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1\ubd84\uae30", - "2\ubd84\uae30", - "3\ubd84\uae30", - "4\ubd84\uae30", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\uc81c 1/4\ubd84\uae30", - "\uc81c 2/4\ubd84\uae30", - "\uc81c 3/4\ubd84\uae30", - "\uc81c 4/4\ubd84\uae30", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\ubd88\uad50\ub825" }, { "calendarname.gregorian", @@ -132,58 +211,15 @@ public class JavaTimeSupplementary_ko extends OpenListResourceBundle { { "field.zone", "\uc2dc\uac04\ub300" }, { "islamic.AmPmMarkers", - new String[] { - "\uc624\uc804", - "\uc624\ud6c4", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y\ub144 M\uc6d4 d\uc77c EEEE", - "GGGG y\ub144 M\uc6d4 d\uc77c", - "GGGG y. M. d.", - "GGGG y. M. d.", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\uc77c", - "\uc6d4", - "\ud654", - "\uc218", - "\ubaa9", - "\uae08", - "\ud1a0", - } - }, + sharedDayNarrows }, { "islamic.DayNames", - new String[] { - "\uc77c\uc694\uc77c", - "\uc6d4\uc694\uc77c", - "\ud654\uc694\uc77c", - "\uc218\uc694\uc77c", - "\ubaa9\uc694\uc77c", - "\uae08\uc694\uc77c", - "\ud1a0\uc694\uc77c", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\uc77c", - "\uc6d4", - "\ud654", - "\uc218", - "\ubaa9", - "\uae08", - "\ud1a0", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "\ubb34\ud558\ub78c", @@ -202,81 +238,25 @@ public class JavaTimeSupplementary_ko extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "1\ubd84\uae30", - "2\ubd84\uae30", - "3\ubd84\uae30", - "4\ubd84\uae30", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\uc81c 1/4\ubd84\uae30", - "\uc81c 2/4\ubd84\uae30", - "\uc81c 3/4\ubd84\uae30", - "\uc81c 4/4\ubd84\uae30", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "a h\uc2dc m\ubd84 s\ucd08 zzzz", - "a h\uc2dc m\ubd84 s\ucd08 z", - "a h:mm:ss", - "a h:mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", new String[] { "AM", "PM", } }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y\ub144 M\uc6d4 d\uc77c EEEE", - "G y\ub144 M\uc6d4 d\uc77c", - "G y. M. d.", - "G y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "G y\ub144 M\uc6d4 d\uc77c EEEE", - "G y\ub144 M\uc6d4 d\uc77c", - "G y. M. d.", - "G y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "G y\ub144 M\uc6d4 d\uc77c EEEE", @@ -286,187 +266,45 @@ public class JavaTimeSupplementary_ko extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "\uc11c\uae30", - "\uba54\uc774\uc9c0", - "\ub2e4\uc774\uc1fc", - "\uc1fc\uc640", - "\ud5e4\uc774\uc138\uc774", - } - }, + sharedJavaTimeShortEras }, { "java.time.japanese.short.Eras", - new String[] { - "\uc11c\uae30", - "\uba54\uc774\uc9c0", - "\ub2e4\uc774\uc1fc", - "\uc1fc\uc640", - "\ud5e4\uc774\uc138\uc774", - } - }, + sharedJavaTimeShortEras }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "java.time.roc.DatePatterns", - new String[] { - "G y\ub144 M\uc6d4 d\uc77c EEEE", - "G y\ub144 M\uc6d4 d\uc77c", - "G y. M. d.", - "G y. M. d.", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "roc.AmPmMarkers", - new String[] { - "\uc624\uc804", - "\uc624\ud6c4", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y\ub144 M\uc6d4 d\uc77c EEEE", - "GGGG y\ub144 M\uc6d4 d\uc77c", - "GGGG y. M. d.", - "GGGG y. M. d.", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\uc77c", - "\uc6d4", - "\ud654", - "\uc218", - "\ubaa9", - "\uae08", - "\ud1a0", - } - }, + sharedDayNarrows }, { "roc.DayNames", - new String[] { - "\uc77c\uc694\uc77c", - "\uc6d4\uc694\uc77c", - "\ud654\uc694\uc77c", - "\uc218\uc694\uc77c", - "\ubaa9\uc694\uc77c", - "\uae08\uc694\uc77c", - "\ud1a0\uc694\uc77c", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\uc77c", - "\uc6d4", - "\ud654", - "\uc218", - "\ubaa9", - "\uae08", - "\ud1a0", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\uc911\ud654\ubbfc\uad6d\uc804", - "\uc911\ud654\ubbfc\uad6d", - } - }, + sharedEras }, { "roc.MonthAbbreviations", - new String[] { - "1\uc6d4", - "2\uc6d4", - "3\uc6d4", - "4\uc6d4", - "5\uc6d4", - "6\uc6d4", - "7\uc6d4", - "8\uc6d4", - "9\uc6d4", - "10\uc6d4", - "11\uc6d4", - "12\uc6d4", - "", - } - }, + sharedMonthNames }, { "roc.MonthNames", - new String[] { - "1\uc6d4", - "2\uc6d4", - "3\uc6d4", - "4\uc6d4", - "5\uc6d4", - "6\uc6d4", - "7\uc6d4", - "8\uc6d4", - "9\uc6d4", - "10\uc6d4", - "11\uc6d4", - "12\uc6d4", - "", - } - }, + sharedMonthNames }, { "roc.MonthNarrows", - new String[] { - "1\uc6d4", - "2\uc6d4", - "3\uc6d4", - "4\uc6d4", - "5\uc6d4", - "6\uc6d4", - "7\uc6d4", - "8\uc6d4", - "9\uc6d4", - "10\uc6d4", - "11\uc6d4", - "12\uc6d4", - "", - } - }, + sharedMonthNames }, { "roc.QuarterAbbreviations", - new String[] { - "1\ubd84\uae30", - "2\ubd84\uae30", - "3\ubd84\uae30", - "4\ubd84\uae30", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\uc81c 1/4\ubd84\uae30", - "\uc81c 2/4\ubd84\uae30", - "\uc81c 3/4\ubd84\uae30", - "\uc81c 4/4\ubd84\uae30", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "a h\uc2dc m\ubd84 s\ucd08 zzzz", - "a h\uc2dc m\ubd84 s\ucd08 z", - "a h:mm:ss", - "a h:mm", - } - }, + sharedTimePatterns }, { "roc.long.Eras", - new String[] { - "\uc911\ud654\ubbfc\uad6d\uc804", - "\uc911\ud654\ubbfc\uad6d", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedEras }, { "roc.narrow.Eras", - new String[] { - "\uc911\ud654\ubbfc\uad6d\uc804", - "\uc911\ud654\ubbfc\uad6d", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "\uc911\ud654\ubbfc\uad6d\uc804", - "\uc911\ud654\ubbfc\uad6d", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java index 715beb1317f..6158a2f8a8d 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java @@ -72,23 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_lt extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "I k.", + "II k.", + "III k.", + "IV k.", + }; + + final String[] sharedQuarterNames = { + "I ketvirtis", + "II ketvirtis", + "III ketvirtis", + "IV ketvirtis", + }; + + final String[] sharedAmPmMarkers = { + "prie\u0161piet", + "popiet", + }; + + final String[] sharedDatePatterns = { + "y MMMM d GGGG, EEEE", + "y MMMM d GGGG", + "y MMM d GGGG", + "y-MM-dd GGGG", + }; + + final String[] sharedDayAbbreviations = { + "sk", + "pr", + "an", + "tr", + "kt", + "pn", + "\u0161t", + }; + + final String[] sharedDayNames = { + "sekmadienis", + "pirmadienis", + "antradienis", + "tre\u010diadienis", + "ketvirtadienis", + "penktadienis", + "\u0161e\u0161tadienis", + }; + + final String[] sharedDayNarrows = { + "S", + "P", + "A", + "T", + "K", + "P", + "\u0160", + }; + + final String[] sharedNarrowAmPmMarkers = { + "pr. p.", + "pop.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "y MMMM d G, EEEE", + "y MMMM d G", + "y MMM d G", + "y-MM-dd G", + }; + + final String[] sharedEras = { + "Prie\u0161 R.O.C.", + "R.O.C.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "I k.", - "II k.", - "III k.", - "IV k.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "I ketvirtis", - "II ketvirtis", - "III ketvirtis", - "IV ketvirtis", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "budist\u0173 kalendorius" }, { "calendarname.gregorian", @@ -126,134 +187,25 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { { "field.zone", "laiko juosta" }, { "islamic.AmPmMarkers", - new String[] { - "prie\u0161piet", - "popiet", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "y MMMM d GGGG, EEEE", - "y MMMM d GGGG", - "y MMM d GGGG", - "y-MM-dd GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "sk", - "pr", - "an", - "tr", - "kt", - "pn", - "\u0161t", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "sekmadienis", - "pirmadienis", - "antradienis", - "tre\u010diadienis", - "ketvirtadienis", - "penktadienis", - "\u0161e\u0161tadienis", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "P", - "A", - "T", - "K", - "P", - "\u0160", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "I k.", - "II k.", - "III k.", - "IV k.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "I ketvirtis", - "II ketvirtis", - "III ketvirtis", - "IV ketvirtis", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "prie\u0161piet", - "popiet", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "pr. p.", - "pop.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "y MMMM d G, EEEE", - "y MMMM d G", - "y MMM d G", - "y-MM-dd G", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -261,21 +213,9 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "y MMMM d G, EEEE", - "y MMMM d G", - "y MMM d G", - "y-MM-dd G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "y MMMM d G, EEEE", - "y MMMM d G", - "y MMM d G", - "y-MM-dd G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", new String[] { "po Kristaus", @@ -301,13 +241,7 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "y MMMM d G, EEEE", - "y MMMM d G", - "y MMM d G", - "y-MM-dd G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "pr.Kr.", @@ -315,58 +249,17 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "prie\u0161piet", - "popiet", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "y MMMM d GGGG, EEEE", - "y MMMM d GGGG", - "y MMM d GGGG", - "y-MM-dd GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "sk", - "pr", - "an", - "tr", - "kt", - "pn", - "\u0161t", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "sekmadienis", - "pirmadienis", - "antradienis", - "tre\u010diadienis", - "ketvirtadienis", - "penktadienis", - "\u0161e\u0161tadienis", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "P", - "A", - "T", - "K", - "P", - "\u0160", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Prie\u0161 R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "saus.", @@ -419,59 +312,19 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "I k.", - "II k.", - "III k.", - "IV k.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "I ketvirtis", - "II ketvirtis", - "III ketvirtis", - "IV ketvirtis", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "prie\u0161piet", - "popiet", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Prie\u0161 R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "pr. p.", - "pop.", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Prie\u0161 R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Prie\u0161 R.O.C.", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lv.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lv.java index c1563a0d0e0..dd503ae7104 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lv.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lv.java @@ -72,31 +72,88 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_lv extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1.\u00a0cet.", + "2.\u00a0cet.", + "3.\u00a0cet.", + "4.\u00a0cet.", + }; + + final String[] sharedQuarterNames = { + "1. ceturksnis", + "2. ceturksnis", + "3. ceturksnis", + "4. ceturksnis", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "priek\u0161pusdien\u0101", + "p\u0113cpusdien\u0101", + }; + + final String[] sharedDatePatterns = { + "EEEE, y. 'gada' d. MMMM GGGG", + "y. 'gada' d. MMMM GGGG", + "y. 'gada' d. MMM GGGG", + "dd.MM.y G", + }; + + final String[] sharedDayAbbreviations = { + "Sv", + "Pr", + "Ot", + "Tr", + "Ce", + "Pk", + "Se", + }; + + final String[] sharedDayNames = { + "sv\u0113tdiena", + "pirmdiena", + "otrdiena", + "tre\u0161diena", + "ceturtdiena", + "piektdiena", + "sestdiena", + }; + + final String[] sharedDayNarrows = { + "S", + "P", + "O", + "T", + "C", + "P", + "S", + }; + + final String[] sharedNarrowAmPmMarkers = { + "priek\u0161p.", + "p\u0113cp.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, y. 'gada' d. MMMM G", + "y. 'gada' d. MMMM G", + "y. 'gada' d. MMM G", + "dd.MM.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1.\u00a0cet.", - "2.\u00a0cet.", - "3.\u00a0cet.", - "4.\u00a0cet.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. ceturksnis", - "2. ceturksnis", - "3. ceturksnis", - "4. ceturksnis", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "budistu kalend\u0101rs" }, { "calendarname.gregorian", @@ -132,52 +189,15 @@ public class JavaTimeSupplementary_lv extends OpenListResourceBundle { { "field.zone", "laika josla" }, { "islamic.AmPmMarkers", - new String[] { - "priek\u0161pusdien\u0101", - "p\u0113cpusdien\u0101", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM GGGG", - "y. 'gada' d. MMMM GGGG", - "y. 'gada' d. MMM GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Sv", - "Pr", - "Ot", - "Tr", - "Ce", - "Pk", - "Se", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "sv\u0113tdiena", - "pirmdiena", - "otrdiena", - "tre\u0161diena", - "ceturtdiena", - "piektdiena", - "sestdiena", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "P", - "O", - "T", - "C", - "P", - "S", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "muharams", @@ -196,73 +216,21 @@ public class JavaTimeSupplementary_lv extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "1.\u00a0cet.", - "2.\u00a0cet.", - "3.\u00a0cet.", - "4.\u00a0cet.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. ceturksnis", - "2. ceturksnis", - "3. ceturksnis", - "4. ceturksnis", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNarrows }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "priek\u0161p.", - "p\u0113cp.", - } - }, + sharedNarrowAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "priek\u0161p.", - "p\u0113cp.", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM G", - "y. 'gada' d. MMMM G", - "y. 'gada' d. MMM G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM G", - "y. 'gada' d. MMMM G", - "y. 'gada' d. MMM G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM G", - "y. 'gada' d. MMMM G", - "y. 'gada' d. MMM G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "pirms m\u016bsu \u0113ras", @@ -270,13 +238,7 @@ public class JavaTimeSupplementary_lv extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM G", - "y. 'gada' d. MMMM G", - "y. 'gada' d. MMM G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "pm\u0113", @@ -284,52 +246,15 @@ public class JavaTimeSupplementary_lv extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "priek\u0161pusdien\u0101", - "p\u0113cpusdien\u0101", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, y. 'gada' d. MMMM GGGG", - "y. 'gada' d. MMMM GGGG", - "y. 'gada' d. MMM GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Sv", - "Pr", - "Ot", - "Tr", - "Ce", - "Pk", - "Se", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "sv\u0113tdiena", - "pirmdiena", - "otrdiena", - "tre\u0161diena", - "ceturtdiena", - "piektdiena", - "sestdiena", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "P", - "O", - "T", - "C", - "P", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "janv.", @@ -382,49 +307,15 @@ public class JavaTimeSupplementary_lv extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1.\u00a0cet.", - "2.\u00a0cet.", - "3.\u00a0cet.", - "4.\u00a0cet.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. ceturksnis", - "2. ceturksnis", - "3. ceturksnis", - "4. ceturksnis", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNarrows }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "priek\u0161p.", - "p\u0113cp.", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "priek\u0161p.", - "p\u0113cp.", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mk.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mk.java index 7c58129b0a1..16ede47d40b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mk.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mk.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_mk extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "\u0458\u0430\u043d-\u043c\u0430\u0440", + "\u0430\u043f\u0440-\u0458\u0443\u043d", + "\u0458\u0443\u043b-\u0441\u0435\u043f", + "\u043e\u043a\u0442-\u0434\u0435\u043a", + }; + + final String[] sharedQuarterNames = { + "\u043f\u0440\u0432\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", + "\u0432\u0442\u043e\u0440\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", + "\u0442\u0440\u0435\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", + "\u0447\u0435\u0442\u0432\u0440\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", + }; + + final String[] sharedAmPmMarkers = { + "\u043f\u0440\u0435\u0442\u043f\u043b\u0430\u0434\u043d\u0435", + "\u043f\u043e\u043f\u043b\u0430\u0434\u043d\u0435", + }; + + final String[] sharedDatePatterns = { + "EEEE, dd MMMM y '\u0433'. GGGG", + "dd MMMM y '\u0433'. GGGG", + "dd.M.y GGGG", + "dd.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "\u043d\u0435\u0434.", + "\u043f\u043e\u043d.", + "\u0432\u0442.", + "\u0441\u0440\u0435.", + "\u0447\u0435\u0442.", + "\u043f\u0435\u0442.", + "\u0441\u0430\u0431.", + }; + + final String[] sharedDayNames = { + "\u043d\u0435\u0434\u0435\u043b\u0430", + "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", + "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", + "\u0441\u0440\u0435\u0434\u0430", + "\u0447\u0435\u0442\u0432\u0440\u0442\u043e\u043a", + "\u043f\u0435\u0442\u043e\u043a", + "\u0441\u0430\u0431\u043e\u0442\u0430", + }; + + final String[] sharedDayNarrows = { + "\u043d", + "\u043f", + "\u0432", + "\u0441", + "\u0447", + "\u043f", + "\u0441", + }; + + final String[] sharedNarrowAmPmMarkers = { + "\u043f\u0440\u0435\u0442.", + "\u043f\u043e\u043f\u043b.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, dd MMMM y '\u0433'. G", + "dd MMMM y '\u0433'. G", + "dd.M.y G", + "dd.M.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u0458\u0430\u043d-\u043c\u0430\u0440", - "\u0430\u043f\u0440-\u0458\u0443\u043d", - "\u0458\u0443\u043b-\u0441\u0435\u043f", - "\u043e\u043a\u0442-\u0434\u0435\u043a", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\u043f\u0440\u0432\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0432\u0442\u043e\u0440\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0442\u0440\u0435\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0447\u0435\u0442\u0432\u0440\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0411\u0443\u0434\u0438\u0441\u0442\u0438\u0447\u043a\u0438 \u043a\u0430\u043b\u0435\u043d\u0434\u0430\u0440" }, { "calendarname.gregorian", @@ -124,120 +180,29 @@ public class JavaTimeSupplementary_mk extends OpenListResourceBundle { { "field.zone", "\u0432\u0440\u0435\u043c\u0435\u043d\u0441\u043a\u0430 \u0437\u043e\u043d\u0430" }, { "islamic.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442\u043f\u043b\u0430\u0434\u043d\u0435", - "\u043f\u043e\u043f\u043b\u0430\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. GGGG", - "dd MMMM y '\u0433'. GGGG", - "dd.M.y GGGG", - "dd.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u043d\u0435\u0434.", - "\u043f\u043e\u043d.", - "\u0432\u0442.", - "\u0441\u0440\u0435.", - "\u0447\u0435\u0442.", - "\u043f\u0435\u0442.", - "\u0441\u0430\u0431.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u043b\u0430", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0440\u0442\u043e\u043a", - "\u043f\u0435\u0442\u043e\u043a", - "\u0441\u0430\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0432", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "\u0458\u0430\u043d-\u043c\u0430\u0440", - "\u0430\u043f\u0440-\u0458\u0443\u043d", - "\u0458\u0443\u043b-\u0441\u0435\u043f", - "\u043e\u043a\u0442-\u0434\u0435\u043a", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u043f\u0440\u0432\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0432\u0442\u043e\u0440\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0442\u0440\u0435\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0447\u0435\u0442\u0432\u0440\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442\u043f\u043b\u0430\u0434\u043d\u0435", - "\u043f\u043e\u043f\u043b\u0430\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442.", - "\u043f\u043e\u043f\u043b.", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. G", - "dd MMMM y '\u0433'. G", - "dd.M.y G", - "dd.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. G", - "dd MMMM y '\u0433'. G", - "dd.M.y G", - "dd.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. G", - "dd MMMM y '\u0433'. G", - "dd.M.y G", - "dd.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u043f\u0440\u0435\u0434 \u043d\u0430\u0448\u0430\u0442\u0430 \u0435\u0440\u0430", @@ -245,13 +210,7 @@ public class JavaTimeSupplementary_mk extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. G", - "dd MMMM y '\u0433'. G", - "dd.M.y G", - "dd.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u043f\u0440.\u043d.\u0435.", @@ -259,52 +218,15 @@ public class JavaTimeSupplementary_mk extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442\u043f\u043b\u0430\u0434\u043d\u0435", - "\u043f\u043e\u043f\u043b\u0430\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, dd MMMM y '\u0433'. GGGG", - "dd MMMM y '\u0433'. GGGG", - "dd.M.y GGGG", - "dd.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u043d\u0435\u0434.", - "\u043f\u043e\u043d.", - "\u0432\u0442.", - "\u0441\u0440\u0435.", - "\u0447\u0435\u0442.", - "\u043f\u0435\u0442.", - "\u0441\u0430\u0431.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u043b\u0430", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0440\u0442\u043e\u043a", - "\u043f\u0435\u0442\u043e\u043a", - "\u0441\u0430\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0432", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u0458\u0430\u043d.", @@ -357,41 +279,13 @@ public class JavaTimeSupplementary_mk extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u0458\u0430\u043d-\u043c\u0430\u0440", - "\u0430\u043f\u0440-\u0458\u0443\u043d", - "\u0458\u0443\u043b-\u0441\u0435\u043f", - "\u043e\u043a\u0442-\u0434\u0435\u043a", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u043f\u0440\u0432\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0432\u0442\u043e\u0440\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0442\u0440\u0435\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - "\u0447\u0435\u0442\u0432\u0440\u0442\u043e \u0442\u0440\u043e\u043c\u0435\u0441\u0435\u0447\u0458\u0435", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442\u043f\u043b\u0430\u0434\u043d\u0435", - "\u043f\u043e\u043f\u043b\u0430\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435\u0442.", - "\u043f\u043e\u043f\u043b.", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ms.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ms.java index 8c4d4fe05c9..5aff378c18b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ms.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ms.java @@ -72,23 +72,86 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ms extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "S1", + "S2", + "S3", + "S4", + }; + + final String[] sharedQuarterNames = { + "Suku pertama", + "Suku Ke-2", + "Suku Ke-3", + "Suku Ke-4", + }; + + final String[] sharedAmPmMarkers = { + "PG", + "PTG", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "dd/MM/y GGGG", + "d/MM/y G", + }; + + final String[] sharedDayAbbreviations = { + "Ahd", + "Isn", + "Sel", + "Rab", + "Kha", + "Jum", + "Sab", + }; + + final String[] sharedDayNames = { + "Ahad", + "Isnin", + "Selasa", + "Rabu", + "Khamis", + "Jumaat", + "Sabtu", + }; + + final String[] sharedDayNarrows = { + "A", + "I", + "S", + "R", + "K", + "J", + "S", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a zzzz", + "h:mm:ss a z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "dd/MM/y G", + "d/MM/y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "S1", - "S2", - "S3", - "S4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "Suku pertama", - "Suku Ke-2", - "Suku Ke-3", - "Suku Ke-4", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Kalendar Buddha" }, { "calendarname.gregorian", @@ -122,134 +185,27 @@ public class JavaTimeSupplementary_ms extends OpenListResourceBundle { { "field.zone", "Zon Waktu" }, { "islamic.AmPmMarkers", - new String[] { - "PG", - "PTG", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "dd/MM/y GGGG", - "d/MM/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Ahd", - "Isn", - "Sel", - "Rab", - "Kha", - "Jum", - "Sab", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Ahad", - "Isnin", - "Selasa", - "Rabu", - "Khamis", - "Jumaat", - "Sabtu", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "A", - "I", - "S", - "R", - "K", - "J", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "S1", - "S2", - "S3", - "S4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "Suku pertama", - "Suku Ke-2", - "Suku Ke-3", - "Suku Ke-4", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "PG", - "PTG", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd/MM/y G", - "d/MM/y GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -257,21 +213,9 @@ public class JavaTimeSupplementary_ms extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "S.M.", @@ -279,13 +223,7 @@ public class JavaTimeSupplementary_ms extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd/MM/y G", - "d/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "BCE", @@ -293,52 +231,15 @@ public class JavaTimeSupplementary_ms extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "PG", - "PTG", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "dd/MM/y GGGG", - "d/MM/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Ahd", - "Isn", - "Sel", - "Rab", - "Kha", - "Jum", - "Sab", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Ahad", - "Isnin", - "Selasa", - "Rabu", - "Khamis", - "Jumaat", - "Sabtu", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "A", - "I", - "S", - "R", - "K", - "J", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "Jan", @@ -391,41 +292,15 @@ public class JavaTimeSupplementary_ms extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "S1", - "S2", - "S3", - "S4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "Suku pertama", - "Suku Ke-2", - "Suku Ke-3", - "Suku Ke-4", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a zzzz", - "h:mm:ss a z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "PG", - "PTG", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mt.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mt.java index d345b43d15f..bf6bb0d1830 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mt.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_mt.java @@ -72,23 +72,69 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_mt extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "1el kwart", + "2ni kwart", + "3et kwart", + "4ba\u2019 kwart", + }; + + final String[] sharedDatePatterns = { + "EEEE, d 'ta'\u2019 MMMM y GGGG", + "d 'ta'\u2019 MMMM y GGGG", + "dd MMM y GGGG", + "dd/MM/y G", + }; + + final String[] sharedDayAbbreviations = { + "\u0126ad", + "Tne", + "Tli", + "Erb", + "\u0126am", + "\u0120im", + "Sib", + }; + + final String[] sharedDayNames = { + "Il-\u0126add", + "It-Tnejn", + "It-Tlieta", + "L-Erbg\u0127a", + "Il-\u0126amis", + "Il-\u0120img\u0127a", + "Is-Sibt", + }; + + final String[] sharedDayNarrows = { + "\u0126", + "T", + "T", + "E", + "\u0126", + "\u0120", + "S", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d 'ta'\u2019 MMMM y G", + "d 'ta'\u2019 MMMM y G", + "dd MMM y G", + "dd/MM/y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1el kwart", - "2ni kwart", - "3et kwart", - "4ba\u2019 kwart", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Kalendarju Buddist" }, { "calendarname.gregorian", @@ -126,94 +172,23 @@ public class JavaTimeSupplementary_mt extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y GGGG", - "d 'ta'\u2019 MMMM y GGGG", - "dd MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u0126ad", - "Tne", - "Tli", - "Erb", - "\u0126am", - "\u0120im", - "Sib", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Il-\u0126add", - "It-Tnejn", - "It-Tlieta", - "L-Erbg\u0127a", - "Il-\u0126amis", - "Il-\u0120img\u0127a", - "Is-Sibt", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u0126", - "T", - "T", - "E", - "\u0126", - "\u0120", - "S", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1el kwart", - "2ni kwart", - "3et kwart", - "4ba\u2019 kwart", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y G", - "d 'ta'\u2019 MMMM y G", - "dd MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y G", - "d 'ta'\u2019 MMMM y G", - "dd MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y G", - "d 'ta'\u2019 MMMM y G", - "dd MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "Qabel Kristu", @@ -221,66 +196,21 @@ public class JavaTimeSupplementary_mt extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y G", - "d 'ta'\u2019 MMMM y G", - "dd MMM y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "QK", "WK", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE, d 'ta'\u2019 MMMM y GGGG", - "d 'ta'\u2019 MMMM y GGGG", - "dd MMM y GGGG", - "dd/MM/y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u0126ad", - "Tne", - "Tli", - "Erb", - "\u0126am", - "\u0120im", - "Sib", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Il-\u0126add", - "It-Tnejn", - "It-Tlieta", - "L-Erbg\u0127a", - "Il-\u0126amis", - "Il-\u0120img\u0127a", - "Is-Sibt", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u0126", - "T", - "T", - "E", - "\u0126", - "\u0120", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "Jan", @@ -333,21 +263,9 @@ public class JavaTimeSupplementary_mt extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1el kwart", - "2ni kwart", - "3et kwart", - "4ba\u2019 kwart", - } - }, + sharedQuarterNames }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java index 37de600827e..38feb02141d 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java @@ -72,23 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_nl extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "1e kwartaal", + "2e kwartaal", + "3e kwartaal", + "4e kwartaal", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd-MM-yy G", + }; + + final String[] sharedDayAbbreviations = { + "zo", + "ma", + "di", + "wo", + "do", + "vr", + "za", + }; + + final String[] sharedDayNames = { + "zondag", + "maandag", + "dinsdag", + "woensdag", + "donderdag", + "vrijdag", + "zaterdag", + }; + + final String[] sharedDayNarrows = { + "Z", + "M", + "D", + "W", + "D", + "V", + "Z", + }; + + final String[] sharedEras = { + "", + "Sa\u02bbna Hizjria", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd-MM-yy GGGGG", + }; + + final String[] sharedShortEras = { + "voor R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1e kwartaal", - "2e kwartaal", - "3e kwartaal", - "4e kwartaal", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Boeddhistische kalender" }, { "calendarname.gregorian", @@ -126,58 +187,17 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { { "field.zone", "tijdzone" }, { "islamic.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd-MM-yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "zo", - "ma", - "di", - "wo", - "do", - "vr", - "za", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "zondag", - "maandag", - "dinsdag", - "woensdag", - "donderdag", - "vrijdag", - "zaterdag", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "Z", - "M", - "D", - "W", - "D", - "V", - "Z", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "Sa\u02bbna Hizjria", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", new String[] { "Moeh.", @@ -213,81 +233,21 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1e kwartaal", - "2e kwartaal", - "3e kwartaal", - "4e kwartaal", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "Sa\u02bbna Hizjria", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "Sa\u02bbna Hizjria", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "Sa\u02bbna Hizjria", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd-MM-yy GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -295,21 +255,9 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd-MM-yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd-MM-yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", new String[] { "na Christus", @@ -335,13 +283,7 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd-MM-yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "v. Chr.", @@ -349,58 +291,17 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd-MM-yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "zo", - "ma", - "di", - "wo", - "do", - "vr", - "za", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "zondag", - "maandag", - "dinsdag", - "woensdag", - "donderdag", - "vrijdag", - "zaterdag", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "Z", - "M", - "D", - "W", - "D", - "V", - "Z", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "voor R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -453,59 +354,19 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1e kwartaal", - "2e kwartaal", - "3e kwartaal", - "4e kwartaal", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "voor R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "voor R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "voor R.O.C.", - "Minguo", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl_BE.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl_BE.java index c7b1d9a0886..d91b3160f88 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl_BE.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl_BE.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ /* * COPYRIGHT AND PERMISSION NOTICE * - * Copyright (C) 1991-2015 Unicode, Inc. All rights reserved. + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. * Distributed under the Terms of Use in * http://www.unicode.org/copyright.html. * @@ -72,55 +72,33 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_nl_BE extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "d/MM/yy G", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "d/MM/yy GGGGG", + }; + return new Object[][] { { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/MM/yy G", - } - }, + sharedDatePatterns }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "d/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "d/MM/yy G", - } - }, + sharedDatePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java index 8b11d758775..5bf80bd3523 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java @@ -72,31 +72,100 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_no extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "1. kvartal", + "2. kvartal", + "3. kvartal", + "4. kvartal", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE d. MMMM y GGGG", + "d. MMMM y GGGG", + "d. MMM y GGGG", + "d.M. y GGGG", + }; + + final String[] sharedDayAbbreviations = { + "s\u00f8n.", + "man.", + "tir.", + "ons.", + "tor.", + "fre.", + "l\u00f8r.", + }; + + final String[] sharedDayNames = { + "s\u00f8ndag", + "mandag", + "tirsdag", + "onsdag", + "torsdag", + "fredag", + "l\u00f8rdag", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "T", + "O", + "T", + "F", + "L", + }; + + final String[] sharedTimePatterns = { + "HH.mm.ss zzzz", + "HH.mm.ss z", + "HH.mm.ss", + "HH.mm", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d. MMMM y G", + "d. MMMM y G", + "d. MMM y G", + "d.M. y G", + }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "buddhistisk kalender" }, { "calendarname.gregorian", @@ -134,58 +203,15 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { { "field.zone", "tidssone" }, { "islamic.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. MMM y GGGG", - "d.M. y GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "s\u00f8n.", - "man.", - "tir.", - "ons.", - "tor.", - "fre.", - "l\u00f8r.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "s\u00f8ndag", - "mandag", - "tirsdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f8rdag", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", new String[] { "muh.", @@ -221,81 +247,19 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "islamic.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d.M. y G", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -303,13 +267,7 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d.M. y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE d. MMMM y G", @@ -343,13 +301,7 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d. MMMM y G", - "d. MMMM y G", - "d. MMM y G", - "d.M. y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "f.Kr.", @@ -357,58 +309,17 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d. MMMM y GGGG", - "d. MMMM y GGGG", - "d. MMM y GGGG", - "d.M. y GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "s\u00f8n.", - "man.", - "tir.", - "ons.", - "tor.", - "fre.", - "l\u00f8r.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "s\u00f8ndag", - "mandag", - "tirsdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f8rdag", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -461,67 +372,23 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. kvartal", - "2. kvartal", - "3. kvartal", - "4. kvartal", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "roc.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pl.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pl.java index db8728fa0fc..c053e5a3410 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pl.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pl.java @@ -72,27 +72,84 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_pl extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "I kwarta\u0142", + "II kwarta\u0142", + "III kwarta\u0142", + "IV kwarta\u0142", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "dd.MM.y GGGG", + }; + + final String[] sharedDayAbbreviations = { + "niedz.", + "pon.", + "wt.", + "\u015br.", + "czw.", + "pt.", + "sob.", + }; + + final String[] sharedDayNames = { + "niedziela", + "poniedzia\u0142ek", + "wtorek", + "\u015broda", + "czwartek", + "pi\u0105tek", + "sobota", + }; + + final String[] sharedDayNarrows = { + "N", + "P", + "W", + "\u015a", + "C", + "P", + "S", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "d MMM y G", + "dd.MM.y G", + }; + + final String[] sharedJavaTimeLongEras = { "p.n.e.", "n.e.", }; + + final String[] sharedEras = { + "Przed ROC", + "ROC", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "I kwarta\u0142", - "II kwarta\u0142", - "III kwarta\u0142", - "IV kwarta\u0142", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "kalendarz buddyjski" }, { "calendarname.gregorian", @@ -136,46 +193,13 @@ public class JavaTimeSupplementary_pl extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd.MM.y GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "niedz.", - "pon.", - "wt.", - "\u015br.", - "czw.", - "pt.", - "sob.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "niedziela", - "poniedzia\u0142ek", - "wtorek", - "\u015broda", - "czwartek", - "pi\u0105tek", - "sobota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "N", - "P", - "W", - "\u015a", - "C", - "P", - "S", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", new String[] { "Muh.", @@ -211,57 +235,13 @@ public class JavaTimeSupplementary_pl extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "I kwarta\u0142", - "II kwarta\u0142", - "III kwarta\u0142", - "IV kwarta\u0142", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.y G", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -269,86 +249,25 @@ public class JavaTimeSupplementary_pl extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "d MMM y G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedJavaTimeLongEras }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "dd.MM.y GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "niedz.", - "pon.", - "wt.", - "\u015br.", - "czw.", - "pt.", - "sob.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "niedziela", - "poniedzia\u0142ek", - "wtorek", - "\u015broda", - "czwartek", - "pi\u0105tek", - "sobota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "N", - "P", - "W", - "\u015a", - "C", - "P", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Przed ROC", - "ROC", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "sty", @@ -401,53 +320,17 @@ public class JavaTimeSupplementary_pl extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "I kwarta\u0142", - "II kwarta\u0142", - "III kwarta\u0142", - "IV kwarta\u0142", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.long.Eras", - new String[] { - "Przed ROC", - "ROC", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Przed ROC", - "ROC", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Przed ROC", - "ROC", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt.java index b1ae4982b19..17f68135852 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_pt extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "T1", + "T2", + "T3", + "T4", + }; + + final String[] sharedQuarterNames = { + "1\u00ba trimestre", + "2\u00ba trimestre", + "3\u00ba trimestre", + "4\u00ba trimestre", + }; + + final String[] sharedDatePatterns = { + "EEEE, d 'de' MMMM 'de' y GGGG", + "d 'de' MMMM 'de' y GGGG", + "dd/MM/y GGGG", + "dd/MM/yy G", + }; + + final String[] sharedDayAbbreviations = { + "dom", + "seg", + "ter", + "qua", + "qui", + "sex", + "s\u00e1b", + }; + + final String[] sharedDayNames = { + "domingo", + "segunda-feira", + "ter\u00e7a-feira", + "quarta-feira", + "quinta-feira", + "sexta-feira", + "s\u00e1bado", + }; + + final String[] sharedDayNarrows = { + "D", + "S", + "T", + "Q", + "Q", + "S", + "S", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d 'de' MMMM 'de' y G", + "d 'de' MMMM 'de' y G", + "dd/MM/y G", + "dd/MM/yy GGGGG", + }; + + final String[] sharedEras = { + "Antes de R.O.C.", + "R.O.C.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Calend\u00e1rio Budista" }, { "calendarname.gregorian", @@ -130,122 +186,21 @@ public class JavaTimeSupplementary_pt extends OpenListResourceBundle { } }, { "islamic.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y GGGG", - "d 'de' MMMM 'de' y GGGG", - "dd/MM/y GGGG", - "dd/MM/yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "dom", - "seg", - "ter", - "qua", - "qui", - "sex", - "s\u00e1b", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "domingo", - "segunda-feira", - "ter\u00e7a-feira", - "quarta-feira", - "quinta-feira", - "sexta-feira", - "s\u00e1bado", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "S", - "T", - "Q", - "Q", - "S", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedQuarterNames }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "dd/MM/y G", - "dd/MM/yy GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -253,21 +208,9 @@ public class JavaTimeSupplementary_pt extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "dd/MM/y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "dd/MM/y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "antes de Cristo", @@ -275,72 +218,23 @@ public class JavaTimeSupplementary_pt extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y G", - "d 'de' MMMM 'de' y G", - "dd/MM/y G", - "dd/MM/yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "a.C.", "d.C.", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE, d 'de' MMMM 'de' y GGGG", - "d 'de' MMMM 'de' y GGGG", - "dd/MM/y GGGG", - "dd/MM/yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "dom", - "seg", - "ter", - "qua", - "qui", - "sex", - "s\u00e1b", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "domingo", - "segunda-feira", - "ter\u00e7a-feira", - "quarta-feira", - "quinta-feira", - "sexta-feira", - "s\u00e1bado", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "S", - "T", - "Q", - "Q", - "S", - "S", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Antes de R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "jan", @@ -393,53 +287,17 @@ public class JavaTimeSupplementary_pt extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "T1", - "T2", - "T3", - "T4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1\u00ba trimestre", - "2\u00ba trimestre", - "3\u00ba trimestre", - "4\u00ba trimestre", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.long.Eras", - new String[] { - "Antes de R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Antes de R.O.C.", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Antes de R.O.C.", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt_PT.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt_PT.java index c9c118b4943..a35e1e1873e 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt_PT.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_pt_PT.java @@ -72,23 +72,52 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_pt_PT extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1.\u00ba trimestre", + "2.\u00ba trimestre", + "3.\u00ba trimestre", + "4.\u00ba trimestre", + }; + + final String[] sharedAmPmMarkers = { + "da manh\u00e3", + "da tarde", + }; + + final String[] sharedDatePatterns = { + "GGGG y MMMM d, EEEE", + "GGGG y MMMM d", + "GGGG y MMM d", + "d/M/y GGGG", + }; + + final String[] sharedDayAbbreviations = { + "domingo", + "segunda", + "ter\u00e7a", + "quarta", + "quinta", + "sexta", + "s\u00e1bado", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G y MMMM d, EEEE", + "G y MMMM d", + "G y MMM d", + "d/M/y G", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1.\u00ba trimestre", - "2.\u00ba trimestre", - "3.\u00ba trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "1.\u00ba trimestre", - "2.\u00ba trimestre", - "3.\u00ba trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "Calend\u00e1rio budista" }, { "calendarname.gregorian", @@ -100,66 +129,21 @@ public class JavaTimeSupplementary_pt_PT extends OpenListResourceBundle { { "calendarname.japanese", "Calend\u00e1rio japon\u00eas" }, { "islamic.AmPmMarkers", - new String[] { - "da manh\u00e3", - "da tarde", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/M/y GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "domingo", - "segunda", - "ter\u00e7a", - "quarta", - "quinta", - "sexta", - "s\u00e1bado", - } - }, + sharedDayAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1.\u00ba trimestre", - "2.\u00ba trimestre", - "3.\u00ba trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedNarrowAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, d 'de' MMMM 'de' y G", @@ -169,58 +153,19 @@ public class JavaTimeSupplementary_pt_PT extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G y MMMM d, EEEE", - "G y MMMM d", - "G y MMM d", - "d/M/y G", - } - }, + sharedJavaTimeDatePatterns }, { "roc.AmPmMarkers", - new String[] { - "da manh\u00e3", - "da tarde", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG y MMMM d, EEEE", - "GGGG y MMMM d", - "GGGG y MMM d", - "d/M/y GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "domingo", - "segunda", - "ter\u00e7a", - "quarta", - "quinta", - "sexta", - "s\u00e1bado", - } - }, + sharedDayAbbreviations }, { "roc.QuarterNames", - new String[] { - "1.\u00ba trimestre", - "2.\u00ba trimestre", - "3.\u00ba trimestre", - "4.\u00ba trimestre", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ro.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ro.java index d12ac5b7b06..242e2bd5b58 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ro.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ro.java @@ -72,23 +72,74 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ro extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "trim. I", + "trim. II", + "trim. III", + "trim. IV", + }; + + final String[] sharedQuarterNames = { + "trimestrul I", + "trimestrul al II-lea", + "trimestrul al III-lea", + "trimestrul al IV-lea", + }; + + final String[] sharedAmPmMarkers = { + "a.m.", + "p.m.", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y GGGG", + "d MMMM y GGGG", + "dd.MM.y GGGG", + "dd.MM.y G", + }; + + final String[] sharedDayAbbreviations = { + "dum.", + "lun.", + "mar.", + "mie.", + "joi", + "vin.", + "s\u00e2m.", + }; + + final String[] sharedDayNames = { + "duminic\u0103", + "luni", + "mar\u021bi", + "miercuri", + "joi", + "vineri", + "s\u00e2mb\u0103t\u0103", + }; + + final String[] sharedDayNarrows = { + "D", + "L", + "M", + "M", + "J", + "V", + "S", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y G", + "d MMMM y G", + "dd.MM.y G", + "dd.MM.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "trim. I", - "trim. II", - "trim. III", - "trim. IV", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "trimestrul I", - "trimestrul al II-lea", - "trimestrul al III-lea", - "trimestrul al IV-lea", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "calendar budist" }, { "calendarname.gregorian", @@ -124,128 +175,25 @@ public class JavaTimeSupplementary_ro extends OpenListResourceBundle { { "field.zone", "Fus orar" }, { "islamic.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "dum.", - "lun.", - "mar.", - "mie.", - "joi", - "vin.", - "s\u00e2m.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "duminic\u0103", - "luni", - "mar\u021bi", - "miercuri", - "joi", - "vineri", - "s\u00e2mb\u0103t\u0103", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "trim. I", - "trim. II", - "trim. III", - "trim. IV", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "trimestrul I", - "trimestrul al II-lea", - "trimestrul al III-lea", - "trimestrul al IV-lea", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", new String[] { "BC", @@ -259,21 +207,9 @@ public class JavaTimeSupplementary_ro extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u00eenainte de Hristos", @@ -281,13 +217,7 @@ public class JavaTimeSupplementary_ro extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y G", - "d MMMM y G", - "dd.MM.y G", - "dd.MM.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "d.C.", @@ -295,52 +225,15 @@ public class JavaTimeSupplementary_ro extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y GGGG", - "d MMMM y GGGG", - "dd.MM.y GGGG", - "dd.MM.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "dum.", - "lun.", - "mar.", - "mie.", - "joi", - "vin.", - "s\u00e2m.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "duminic\u0103", - "luni", - "mar\u021bi", - "miercuri", - "joi", - "vineri", - "s\u00e2mb\u0103t\u0103", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "L", - "M", - "M", - "J", - "V", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "ian.", @@ -393,41 +286,13 @@ public class JavaTimeSupplementary_ro extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "trim. I", - "trim. II", - "trim. III", - "trim. IV", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "trimestrul I", - "trimestrul al II-lea", - "trimestrul al III-lea", - "trimestrul al IV-lea", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "a.m.", - "p.m.", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java index 977e1b784a3..b9e50a03acd 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java @@ -72,23 +72,92 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_ru extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1-\u0439 \u043a\u0432.", + "2-\u0439 \u043a\u0432.", + "3-\u0439 \u043a\u0432.", + "4-\u0439 \u043a\u0432.", + }; + + final String[] sharedQuarterNames = { + "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + }; + + final String[] sharedAmPmMarkers = { + "\u0414\u041f", + "\u041f\u041f", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y '\u0433'. GGGG", + "d MMMM y '\u0433'. GGGG", + "d MMM y '\u0433'. GGGG", + "dd.MM.y GGGG", + }; + + final String[] sharedDayNarrows = { + "\u0432\u0441", + "\u043f\u043d", + "\u0432\u0442", + "\u0441\u0440", + "\u0447\u0442", + "\u043f\u0442", + "\u0441\u0431", + }; + + final String[] sharedDayNames = { + "\u0432\u043e\u0441\u043a\u0440\u0435\u0441\u0435\u043d\u044c\u0435", + "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u044c\u043d\u0438\u043a", + "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", + "\u0441\u0440\u0435\u0434\u0430", + "\u0447\u0435\u0442\u0432\u0435\u0440\u0433", + "\u043f\u044f\u0442\u043d\u0438\u0446\u0430", + "\u0441\u0443\u0431\u0431\u043e\u0442\u0430", + }; + + final String[] sharedMonthNames = { + "\u041c\u0443\u0445\u0430\u0440\u0440\u0430\u043c", + "\u0421\u0430\u0444\u0430\u0440", + "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", + "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", + "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", + "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", + "\u0420\u0430\u0434\u0436\u0430\u0431", + "\u0428\u0430\u0430\u0431\u0430\u043d", + "\u0420\u0430\u043c\u0430\u0434\u0430\u043d", + "\u0428\u0430\u0432\u0432\u0430\u043b\u044c", + "\u0417\u0443\u043b\u044c-\u041a\u0430\u0430\u0434\u0430", + "\u0417\u0443\u043b\u044c-\u0425\u0438\u0434\u0436\u0436\u0430", + "", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y '\u0433'. G", + "d MMMM y '\u0433'. G", + "d MMM y '\u0433'. G", + "dd.MM.y G", + }; + + final String[] sharedEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0431\u0443\u0434\u0434\u0438\u0439\u0441\u043a\u0438\u0439 \u043a\u0430\u043b\u0435\u043d\u0434\u0430\u0440\u044c" }, { "calendarname.gregorian", @@ -126,144 +195,31 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { { "field.zone", "\u0447\u0430\u0441\u043e\u0432\u043e\u0439 \u043f\u043e\u044f\u0441" }, { "islamic.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. GGGG", - "d MMMM y '\u0433'. GGGG", - "d MMM y '\u0433'. GGGG", - "dd.MM.y GGGG", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u0432\u0441", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayNarrows }, { "islamic.DayNames", - new String[] { - "\u0432\u043e\u0441\u043a\u0440\u0435\u0441\u0435\u043d\u044c\u0435", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u044c\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0435\u0440\u0433", - "\u043f\u044f\u0442\u043d\u0438\u0446\u0430", - "\u0441\u0443\u0431\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u0432\u0441", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayNarrows }, { "islamic.MonthAbbreviations", - new String[] { - "\u041c\u0443\u0445\u0430\u0440\u0440\u0430\u043c", - "\u0421\u0430\u0444\u0430\u0440", - "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", - "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", - "\u0420\u0430\u0434\u0436\u0430\u0431", - "\u0428\u0430\u0430\u0431\u0430\u043d", - "\u0420\u0430\u043c\u0430\u0434\u0430\u043d", - "\u0428\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0417\u0443\u043b\u044c-\u041a\u0430\u0430\u0434\u0430", - "\u0417\u0443\u043b\u044c-\u0425\u0438\u0434\u0436\u0436\u0430", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNames", - new String[] { - "\u041c\u0443\u0445\u0430\u0440\u0440\u0430\u043c", - "\u0421\u0430\u0444\u0430\u0440", - "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0420\u0430\u0431\u0438-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", - "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0414\u0436\u0443\u043c\u0430\u0434-\u0443\u043b\u044c-\u0430\u0445\u0438\u0440", - "\u0420\u0430\u0434\u0436\u0430\u0431", - "\u0428\u0430\u0430\u0431\u0430\u043d", - "\u0420\u0430\u043c\u0430\u0434\u0430\u043d", - "\u0428\u0430\u0432\u0432\u0430\u043b\u044c", - "\u0417\u0443\u043b\u044c-\u041a\u0430\u0430\u0434\u0430", - "\u0417\u0443\u043b\u044c-\u0425\u0438\u0434\u0436\u0436\u0430", - "", - } - }, + sharedMonthNames }, { "islamic.QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d MMM y '\u0433'. G", - "dd.MM.y G", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -271,21 +227,9 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d MMM y '\u0433'. G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d MMM y '\u0433'. G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", new String[] { "\u043e\u0442 \u0420\u043e\u0436\u0434\u0435\u0441\u0442\u0432\u0430 \u0425\u0440\u0438\u0441\u0442\u043e\u0432\u0430", @@ -311,13 +255,7 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. G", - "d MMMM y '\u0433'. G", - "d MMM y '\u0433'. G", - "dd.MM.y G", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u0434\u043e \u043d.\u044d.", @@ -325,58 +263,17 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0433'. GGGG", - "d MMMM y '\u0433'. GGGG", - "d MMM y '\u0433'. GGGG", - "dd.MM.y GGGG", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u0432\u0441", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayNarrows }, { "roc.DayNames", - new String[] { - "\u0432\u043e\u0441\u043a\u0440\u0435\u0441\u0435\u043d\u044c\u0435", - "\u043f\u043e\u043d\u0435\u0434\u0435\u043b\u044c\u043d\u0438\u043a", - "\u0432\u0442\u043e\u0440\u043d\u0438\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0435\u0440\u0433", - "\u043f\u044f\u0442\u043d\u0438\u0446\u0430", - "\u0441\u0443\u0431\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u0432\u0441", - "\u043f\u043d", - "\u0432\u0442", - "\u0441\u0440", - "\u0447\u0442", - "\u043f\u0442", - "\u0441\u0431", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "\u044f\u043d\u0432.", @@ -429,59 +326,21 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u0414\u041f", - "\u041f\u041f", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sk.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sk.java index 5da8b943720..156c1fba69e 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sk.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sk.java @@ -72,15 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sk extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "1. \u0161tvr\u0165rok", + "2. \u0161tvr\u0165rok", + "3. \u0161tvr\u0165rok", + "4. \u0161tvr\u0165rok", + }; + + final String[] sharedAmPmMarkers = { + "AM", + "PM", + }; + + final String[] sharedDatePatterns = { + "EEEE, d. M. y GGGG", + "d. M. y GGGG", + "d. M. y GGGG", + "d.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "ne", + "po", + "ut", + "st", + "\u0161t", + "pi", + "so", + }; + + final String[] sharedDayNames = { + "nede\u013ea", + "pondelok", + "utorok", + "streda", + "\u0161tvrtok", + "piatok", + "sobota", + }; + + final String[] sharedDayNarrows = { + "n", + "p", + "u", + "s", + "\u0161", + "p", + "s", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedTimePatterns = { + "H:mm:ss zzzz", + "H:mm:ss z", + "H:mm:ss", + "H:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d. M. y G", + "d. M. y G", + "d. M. y G", + "d.M.y GGGGG", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "1. \u0161tvr\u0165rok", - "2. \u0161tvr\u0165rok", - "3. \u0161tvr\u0165rok", - "4. \u0161tvr\u0165rok", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "buddhistick\u00fd kalend\u00e1r" }, { "calendarname.gregorian", @@ -116,114 +180,29 @@ public class JavaTimeSupplementary_sk extends OpenListResourceBundle { { "field.zone", "\u010dasov\u00e9 p\u00e1smo" }, { "islamic.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d. M. y GGGG", - "d. M. y GGGG", - "d. M. y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "ne", - "po", - "ut", - "st", - "\u0161t", - "pi", - "so", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "nede\u013ea", - "pondelok", - "utorok", - "streda", - "\u0161tvrtok", - "piatok", - "sobota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "n", - "p", - "u", - "s", - "\u0161", - "p", - "s", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. \u0161tvr\u0165rok", - "2. \u0161tvr\u0165rok", - "3. \u0161tvr\u0165rok", - "4. \u0161tvr\u0165rok", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, + sharedTimePatterns }, { "islamic.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d. M. y G", - "d. M. y G", - "d. M. y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d. M. y G", - "d. M. y G", - "d. M. y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d. M. y G", - "d. M. y G", - "d. M. y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "pred Kristom", @@ -231,66 +210,21 @@ public class JavaTimeSupplementary_sk extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d. M. y G", - "d. M. y G", - "d. M. y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "pred n.l.", "n.l.", } }, - { "roc.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, { "roc.DatePatterns", - new String[] { - "EEEE, d. M. y GGGG", - "d. M. y GGGG", - "d. M. y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "ne", - "po", - "ut", - "st", - "\u0161t", - "pi", - "so", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "nede\u013ea", - "pondelok", - "utorok", - "streda", - "\u0161tvrtok", - "piatok", - "sobota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "n", - "p", - "u", - "s", - "\u0161", - "p", - "s", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "jan", @@ -343,35 +277,11 @@ public class JavaTimeSupplementary_sk extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. \u0161tvr\u0165rok", - "2. \u0161tvr\u0165rok", - "3. \u0161tvr\u0165rok", - "4. \u0161tvr\u0165rok", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H:mm:ss zzzz", - "H:mm:ss z", - "H:mm:ss", - "H:mm", - } - }, - { "roc.narrow.AmPmMarkers", - new String[] { - "AM", - "PM", - } - }, + sharedTimePatterns }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sl.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sl.java index 0ae069b6fe0..26149956100 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sl.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sl.java @@ -72,23 +72,79 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sl extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1. \u010det.", + "2. \u010det.", + "3. \u010det.", + "4. \u010det.", + }; + + final String[] sharedQuarterNames = { + "1. \u010detrtletje", + "2. \u010detrtletje", + "3. \u010detrtletje", + "4. \u010detrtletje", + }; + + final String[] sharedAmPmMarkers = { + "dop.", + "pop.", + }; + + final String[] sharedDatePatterns = { + "EEEE, dd. MMMM y GGGG", + "dd. MMMM y GGGG", + "d. MMM y GGGG", + "d. MM. yy G", + }; + + final String[] sharedDayAbbreviations = { + "ned.", + "pon.", + "tor.", + "sre.", + "\u010det.", + "pet.", + "sob.", + }; + + final String[] sharedDayNames = { + "nedelja", + "ponedeljek", + "torek", + "sreda", + "\u010detrtek", + "petek", + "sobota", + }; + + final String[] sharedDayNarrows = { + "n", + "p", + "t", + "s", + "\u010d", + "p", + "s", + }; + + final String[] sharedNarrowAmPmMarkers = { + "d", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, dd. MMMM y G", + "dd. MMMM y G", + "d. MMM y G", + "d. MM. yy GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1. \u010det.", - "2. \u010det.", - "3. \u010det.", - "4. \u010det.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. \u010detrtletje", - "2. \u010detrtletje", - "3. \u010detrtletje", - "4. \u010detrtletje", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "budisti\u010dni koledar" }, { "calendarname.gregorian", @@ -124,120 +180,29 @@ public class JavaTimeSupplementary_sl extends OpenListResourceBundle { { "field.zone", "\u010dasovni pas" }, { "islamic.AmPmMarkers", - new String[] { - "dop.", - "pop.", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, dd. MMMM y GGGG", - "dd. MMMM y GGGG", - "d. MMM y GGGG", - "d. MM. yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "ned.", - "pon.", - "tor.", - "sre.", - "\u010det.", - "pet.", - "sob.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "nedelja", - "ponedeljek", - "torek", - "sreda", - "\u010detrtek", - "petek", - "sobota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "n", - "p", - "t", - "s", - "\u010d", - "p", - "s", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "1. \u010det.", - "2. \u010det.", - "3. \u010det.", - "4. \u010det.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. \u010detrtletje", - "2. \u010detrtletje", - "3. \u010detrtletje", - "4. \u010detrtletje", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "dop.", - "pop.", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "d", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, dd. MMMM y G", - "dd. MMMM y G", - "d. MMM y G", - "d. MM. yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, dd. MMMM y G", - "dd. MMMM y G", - "d. MMM y G", - "d. MM. yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, dd. MMMM y G", - "dd. MMMM y G", - "d. MMM y G", - "d. MM. yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "pred Kristusom", @@ -245,13 +210,7 @@ public class JavaTimeSupplementary_sl extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, dd. MMMM y G", - "dd. MMMM y G", - "d. MMM y G", - "d. MM. yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "pr.n.\u0161.", @@ -259,52 +218,15 @@ public class JavaTimeSupplementary_sl extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "dop.", - "pop.", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, dd. MMMM y GGGG", - "dd. MMMM y GGGG", - "d. MMM y GGGG", - "d. MM. yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "ned.", - "pon.", - "tor.", - "sre.", - "\u010det.", - "pet.", - "sob.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "nedelja", - "ponedeljek", - "torek", - "sreda", - "\u010detrtek", - "petek", - "sobota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "n", - "p", - "t", - "s", - "\u010d", - "p", - "s", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -357,41 +279,13 @@ public class JavaTimeSupplementary_sl extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1. \u010det.", - "2. \u010det.", - "3. \u010det.", - "4. \u010det.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. \u010detrtletje", - "2. \u010detrtletje", - "3. \u010detrtletje", - "4. \u010detrtletje", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "dop.", - "pop.", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "d", - "p", - } - }, + sharedNarrowAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sq.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sq.java index 96ef053f261..b4daea70146 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sq.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sq.java @@ -72,23 +72,81 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sq extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "tremujori I", + "tremujori II", + "tremujori III", + "tremujori IV", + }; + + final String[] sharedQuarterNames = { + "tremujori i par\u00eb", + "tremujori i dyt\u00eb", + "tremujori i tret\u00eb", + "tremujori i kat\u00ebrt", + }; + + final String[] sharedAmPmMarkers = { + "e paradites", + "e pasdites", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMM y GGGG", + "d MMM y GGGG", + "d MMM y GGGG", + "d.M.y G", + }; + + final String[] sharedDayAbbreviations = { + "Die", + "H\u00ebn", + "Mar", + "M\u00ebr", + "Enj", + "Pre", + "Sht", + }; + + final String[] sharedDayNames = { + "e diel", + "e h\u00ebn\u00eb", + "e mart\u00eb", + "e m\u00ebrkur\u00eb", + "e enjte", + "e premte", + "e shtun\u00eb", + }; + + final String[] sharedDayNarrows = { + "D", + "H", + "M", + "M", + "E", + "P", + "S", + }; + + final String[] sharedTimePatterns = { + "h:mm:ss a, zzzz", + "h:mm:ss a, z", + "h:mm:ss a", + "h:mm a", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMM y G", + "d MMM y G", + "d MMM y G", + "d.M.y GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "tremujori I", - "tremujori II", - "tremujori III", - "tremujori IV", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "tremujori i par\u00eb", - "tremujori i dyt\u00eb", - "tremujori i tret\u00eb", - "tremujori i kat\u00ebrt", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "kalendar budist" }, { "calendarname.gregorian", @@ -126,120 +184,31 @@ public class JavaTimeSupplementary_sq extends OpenListResourceBundle { { "field.zone", "brezi orar" }, { "islamic.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMM y GGGG", - "d MMM y GGGG", - "d MMM y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Die", - "H\u00ebn", - "Mar", - "M\u00ebr", - "Enj", - "Pre", - "Sht", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "e diel", - "e h\u00ebn\u00eb", - "e mart\u00eb", - "e m\u00ebrkur\u00eb", - "e enjte", - "e premte", - "e shtun\u00eb", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "D", - "H", - "M", - "M", - "E", - "P", - "S", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "tremujori I", - "tremujori II", - "tremujori III", - "tremujori IV", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "tremujori i par\u00eb", - "tremujori i dyt\u00eb", - "tremujori i tret\u00eb", - "tremujori i kat\u00ebrt", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "h:mm:ss a, zzzz", - "h:mm:ss a, z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMM y G", - "d MMM y G", - "d MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMM y G", - "d MMM y G", - "d MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMM y G", - "d MMM y G", - "d MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "para er\u00ebs s\u00eb re", @@ -247,13 +216,7 @@ public class JavaTimeSupplementary_sq extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMM y G", - "d MMM y G", - "d MMM y G", - "d.M.y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "p.e.r.", @@ -261,52 +224,15 @@ public class JavaTimeSupplementary_sq extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMM y GGGG", - "d MMM y GGGG", - "d MMM y GGGG", - "d.M.y G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Die", - "H\u00ebn", - "Mar", - "M\u00ebr", - "Enj", - "Pre", - "Sht", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "e diel", - "e h\u00ebn\u00eb", - "e mart\u00eb", - "e m\u00ebrkur\u00eb", - "e enjte", - "e premte", - "e shtun\u00eb", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "D", - "H", - "M", - "M", - "E", - "P", - "S", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "Jan", @@ -359,41 +285,15 @@ public class JavaTimeSupplementary_sq extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "tremujori I", - "tremujori II", - "tremujori III", - "tremujori IV", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "tremujori i par\u00eb", - "tremujori i dyt\u00eb", - "tremujori i tret\u00eb", - "tremujori i kat\u00ebrt", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "h:mm:ss a, zzzz", - "h:mm:ss a, z", - "h:mm:ss a", - "h:mm a", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "e paradites", - "e pasdites", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java index 840d8c48661..1aa88241665 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java @@ -72,31 +72,110 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sr extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "\u041a1", + "\u041a2", + "\u041a3", + "\u041a4", + }; + + final String[] sharedQuarterNames = { + "\u043f\u0440\u0432\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "\u0434\u0440\u0443\u0433\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "\u0442\u0440\u0435\u045b\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "\u0447\u0435\u0442\u0432\u0440\u0442\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "\u043f\u0440\u0435 \u043f\u043e\u0434\u043d\u0435", + "\u043f\u043e \u043f\u043e\u0434\u043d\u0435", + }; + + final String[] sharedDatePatterns = { + "EEEE, dd. MMMM y. GGGG", + "dd. MMMM y. GGGG", + "dd.MM.y. GGGG", + "d.M.y. G", + }; + + final String[] sharedDayAbbreviations = { + "\u043d\u0435\u0434", + "\u043f\u043e\u043d", + "\u0443\u0442\u043e", + "\u0441\u0440\u0435", + "\u0447\u0435\u0442", + "\u043f\u0435\u0442", + "\u0441\u0443\u0431", + }; + + final String[] sharedDayNames = { + "\u043d\u0435\u0434\u0435\u0459\u0430", + "\u043f\u043e\u043d\u0435\u0434\u0435\u0459\u0430\u043a", + "\u0443\u0442\u043e\u0440\u0430\u043a", + "\u0441\u0440\u0435\u0434\u0430", + "\u0447\u0435\u0442\u0432\u0440\u0442\u0430\u043a", + "\u043f\u0435\u0442\u0430\u043a", + "\u0441\u0443\u0431\u043e\u0442\u0430", + }; + + final String[] sharedDayNarrows = { + "\u043d", + "\u043f", + "\u0443", + "\u0441", + "\u0447", + "\u043f", + "\u0441", + }; + + final String[] sharedEras = { + "", + "\u0410\u0425", + }; + + final String[] sharedTimePatterns = { + "HH.mm.ss zzzz", + "HH.mm.ss z", + "HH.mm.ss", + "HH.mm", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, dd. MMMM y. G", + "dd. MMMM y. G", + "dd.MM.y. G", + "d.M.y. GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { + "BC", + "\u0411\u0415", + }; + + final String[] sharedShortEras = { + "\u041f\u0440\u0435 \u0420\u041a", + "\u0420\u041a", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u041a1", - "\u041a2", - "\u041a3", - "\u041a4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\u043f\u0440\u0432\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0434\u0440\u0443\u0433\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0442\u0440\u0435\u045b\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0447\u0435\u0442\u0432\u0440\u0442\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "\u0431\u0443\u0434\u0438\u0441\u0442\u0438\u0447\u043a\u0438 \u043a\u0430\u043b\u0435\u043d\u0434\u0430\u0440" }, { "calendarname.gregorian", @@ -132,58 +211,17 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { { "field.zone", "\u0432\u0440\u0435\u043c\u0435\u043d\u0441\u043a\u0430 \u0437\u043e\u043d\u0430" }, { "islamic.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435 \u043f\u043e\u0434\u043d\u0435", - "\u043f\u043e \u043f\u043e\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, dd. MMMM y. GGGG", - "dd. MMMM y. GGGG", - "dd.MM.y. GGGG", - "d.M.y. G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u043d\u0435\u0434", - "\u043f\u043e\u043d", - "\u0443\u0442\u043e", - "\u0441\u0440\u0435", - "\u0447\u0435\u0442", - "\u043f\u0435\u0442", - "\u0441\u0443\u0431", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u0459\u0430", - "\u043f\u043e\u043d\u0435\u0434\u0435\u0459\u0430\u043a", - "\u0443\u0442\u043e\u0440\u0430\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0440\u0442\u0430\u043a", - "\u043f\u0435\u0442\u0430\u043a", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0443", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "\u0410\u0425", - } - }, + sharedEras }, { "islamic.MonthNames", new String[] { "\u041c\u0443\u0440\u0430\u0445\u0430\u043c", @@ -202,95 +240,31 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "\u041a1", - "\u041a2", - "\u041a3", - "\u041a4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u043f\u0440\u0432\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0434\u0440\u0443\u0433\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0442\u0440\u0435\u045b\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0447\u0435\u0442\u0432\u0440\u0442\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "islamic.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435 \u043f\u043e\u0434\u043d\u0435", - "\u043f\u043e \u043f\u043e\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "\u0410\u0425", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "\u0410\u0425", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u0410\u0425", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, dd. MMMM y. G", - "dd. MMMM y. G", - "dd.MM.y. G", - "d.M.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "\u0411\u0415", - } - }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - new String[] { - "BC", - "\u0411\u0415", - } - }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, dd. MMMM y. G", - "dd. MMMM y. G", - "dd.MM.y. G", - "d.M.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "EEEE, MMMM d, y G", @@ -324,13 +298,7 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, dd. MMMM y. G", - "dd. MMMM y. G", - "dd.MM.y. G", - "d.M.y. GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u043f. \u043d. \u0435.", @@ -338,58 +306,17 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435 \u043f\u043e\u0434\u043d\u0435", - "\u043f\u043e \u043f\u043e\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, dd. MMMM y. GGGG", - "dd. MMMM y. GGGG", - "dd.MM.y. GGGG", - "d.M.y. G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u043d\u0435\u0434", - "\u043f\u043e\u043d", - "\u0443\u0442\u043e", - "\u0441\u0440\u0435", - "\u0447\u0435\u0442", - "\u043f\u0435\u0442", - "\u0441\u0443\u0431", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u043d\u0435\u0434\u0435\u0459\u0430", - "\u043f\u043e\u043d\u0435\u0434\u0435\u0459\u0430\u043a", - "\u0443\u0442\u043e\u0440\u0430\u043a", - "\u0441\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0440\u0442\u0430\u043a", - "\u043f\u0435\u0442\u0430\u043a", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u043d", - "\u043f", - "\u0443", - "\u0441", - "\u0447", - "\u043f", - "\u0441", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\u041f\u0440\u0435 \u0420\u041a", - "\u0420\u041a", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", new String[] { "\u0458\u0430\u043d", @@ -442,67 +369,23 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u041a1", - "\u041a2", - "\u041a3", - "\u041a4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u043f\u0440\u0432\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0434\u0440\u0443\u0433\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0442\u0440\u0435\u045b\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "\u0447\u0435\u0442\u0432\u0440\u0442\u0438 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "roc.TimePatterns", - new String[] { - "HH.mm.ss zzzz", - "HH.mm.ss z", - "HH.mm.ss", - "HH.mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u043f\u0440\u0435 \u043f\u043e\u0434\u043d\u0435", - "\u043f\u043e \u043f\u043e\u0434\u043d\u0435", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "\u041f\u0440\u0435 \u0420\u041a", - "\u0420\u041a", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "\u041f\u0440\u0435 \u0420\u041a", - "\u0420\u041a", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "\u041f\u0440\u0435 \u0420\u041a", - "\u0420\u041a", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_BA.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_BA.java new file mode 100644 index 00000000000..1ecfba1c210 --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_BA.java @@ -0,0 +1,89 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_sr_BA extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedTimePatterns = { + "HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + return new Object[][] { + { "islamic.TimePatterns", + sharedTimePatterns }, + { "roc.TimePatterns", + sharedTimePatterns }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java index 584cd695b7d..016c5c56690 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java @@ -72,23 +72,75 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "prvi kvartal", + "drugi kvartal", + "tre\u0107i kvartal", + "\u010detvrti kvartal", + }; + + final String[] sharedAmPmMarkers = { + "pre podne", + "po podne", + }; + + final String[] sharedDayAbbreviations = { + "ned", + "pon", + "uto", + "sre", + "\u010det", + "pet", + "sub", + }; + + final String[] sharedDayNames = { + "nedelja", + "ponedeljak", + "utorak", + "sreda", + "\u010detvrtak", + "petak", + "subota", + }; + + final String[] sharedDayNarrows = { + "n", + "p", + "u", + "s", + "\u010d", + "p", + "s", + }; + + final String[] sharedEras = { + "", + "AH", + }; + + final String[] sharedJavaTimeLongEras = { + "BC", + "BE", + }; + + final String[] sharedShortEras = { + "Pre RK", + "RK", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "prvi kvartal", - "drugi kvartal", - "tre\u0107i kvartal", - "\u010detvrti kvartal", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "budisti\u010dki kalendar" }, { "calendarname.gregorian", @@ -124,50 +176,15 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { { "field.zone", "vremenska zona" }, { "islamic.AmPmMarkers", - new String[] { - "pre podne", - "po podne", - } - }, + sharedAmPmMarkers }, { "islamic.DayAbbreviations", - new String[] { - "ned", - "pon", - "uto", - "sre", - "\u010det", - "pet", - "sub", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "nedelja", - "ponedeljak", - "utorak", - "sreda", - "\u010detvrtak", - "petak", - "subota", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "n", - "p", - "u", - "s", - "\u010d", - "p", - "s", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.MonthNames", new String[] { "Muraham", @@ -186,57 +203,21 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "prvi kvartal", - "drugi kvartal", - "tre\u0107i kvartal", - "\u010detvrti kvartal", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "pre podne", - "po podne", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedEras }, { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.long.Eras", new String[] { "nove ere", @@ -268,50 +249,15 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "pre podne", - "po podne", - } - }, + sharedAmPmMarkers }, { "roc.DayAbbreviations", - new String[] { - "ned", - "pon", - "uto", - "sre", - "\u010det", - "pet", - "sub", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "nedelja", - "ponedeljak", - "utorak", - "sreda", - "\u010detvrtak", - "petak", - "subota", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "n", - "p", - "u", - "s", - "\u010d", - "p", - "s", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Pre RK", - "RK", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", new String[] { "jan", @@ -364,45 +310,17 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "prvi kvartal", - "drugi kvartal", - "tre\u0107i kvartal", - "\u010detvrti kvartal", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "pre podne", - "po podne", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Pre RK", - "RK", - } - }, + sharedShortEras }, { "roc.narrow.Eras", - new String[] { - "Pre RK", - "RK", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "Pre RK", - "RK", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java index 76632da7020..637f500918c 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java @@ -72,27 +72,91 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_sv extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterAbbreviations = { + "K1", + "K2", + "K3", + "K4", + }; + + final String[] sharedQuarterNames = { + "1:a kvartalet", + "2:a kvartalet", + "3:e kvartalet", + "4:e kvartalet", + }; + + final String[] sharedAmPmMarkers = { + "fm", + "em", + }; + + final String[] sharedDatePatterns = { + "EEEE d MMMM y GGGG", + "d MMMM y GGGG", + "d MMM y GGGG", + "GGGG y-MM-dd", + }; + + final String[] sharedDayAbbreviations = { + "s\u00f6n", + "m\u00e5n", + "tis", + "ons", + "tors", + "fre", + "l\u00f6r", + }; + + final String[] sharedDayNames = { + "s\u00f6ndag", + "m\u00e5ndag", + "tisdag", + "onsdag", + "torsdag", + "fredag", + "l\u00f6rdag", + }; + + final String[] sharedDayNarrows = { + "S", + "M", + "T", + "O", + "T", + "F", + "L", + }; + + final String[] sharedTimePatterns = { + "'kl'. HH:mm:ss zzzz", + "HH:mm:ss z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE d MMMM y G", + "d MMMM y G", + "d MMM y G", + "G y-MM-dd", + }; + + final String[] sharedJavaTimeLongEras = { "f\u00f6re Kristus", "efter Kristus", }; + + final String[] sharedEras = { + "f\u00f6re R.K.", + "R.K.", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1:a kvartalet", - "2:a kvartalet", - "3:e kvartalet", - "4:e kvartalet", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "buddistisk kalender" }, { "calendarname.gregorian", @@ -130,58 +194,15 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { { "field.zone", "tidszon" }, { "islamic.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "GGGG y-MM-dd", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "s\u00f6n", - "m\u00e5n", - "tis", - "ons", - "tors", - "fre", - "l\u00f6r", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "s\u00f6ndag", - "m\u00e5ndag", - "tisdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f6rdag", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "muharram", @@ -200,81 +221,17 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1:a kvartalet", - "2:a kvartalet", - "3:e kvartalet", - "4:e kvartalet", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "'kl'. HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "G y-MM-dd", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -282,21 +239,9 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "G y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "G y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.long.Eras", new String[] { "efter Kristus", @@ -316,70 +261,23 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { } }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE d MMMM y G", - "d MMMM y G", - "d MMM y G", - "G y-MM-dd", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "roc.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE d MMMM y GGGG", - "d MMMM y GGGG", - "d MMM y GGGG", - "GGGG y-MM-dd", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "s\u00f6n", - "m\u00e5n", - "tis", - "ons", - "tors", - "fre", - "l\u00f6r", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "s\u00f6ndag", - "m\u00e5ndag", - "tisdag", - "onsdag", - "torsdag", - "fredag", - "l\u00f6rdag", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "S", - "M", - "T", - "O", - "T", - "F", - "L", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "f\u00f6re R.K.", - "R.K.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "jan.", @@ -432,59 +330,21 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "K1", - "K2", - "K3", - "K4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1:a kvartalet", - "2:a kvartalet", - "3:e kvartalet", - "4:e kvartalet", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "'kl'. HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "f\u00f6re R.K.", - "R.K.", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "fm", - "em", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "f\u00f6re R.K.", - "R.K.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "f\u00f6re R.K.", - "R.K.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java index bb5169858db..8b7a08543d9 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java @@ -72,23 +72,99 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_th extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterNames = { + "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", + "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", + "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", + "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", + }; + + final String[] sharedAmPmMarkers = { + "\u0e01\u0e48\u0e2d\u0e19\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", + "\u0e2b\u0e25\u0e31\u0e07\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", + }; + + final String[] sharedDayAbbreviations = { + "\u0e2d\u0e32.", + "\u0e08.", + "\u0e2d.", + "\u0e1e.", + "\u0e1e\u0e24.", + "\u0e28.", + "\u0e2a.", + }; + + final String[] sharedDayNames = { + "\u0e27\u0e31\u0e19\u0e2d\u0e32\u0e17\u0e34\u0e15\u0e22\u0e4c", + "\u0e27\u0e31\u0e19\u0e08\u0e31\u0e19\u0e17\u0e23\u0e4c", + "\u0e27\u0e31\u0e19\u0e2d\u0e31\u0e07\u0e04\u0e32\u0e23", + "\u0e27\u0e31\u0e19\u0e1e\u0e38\u0e18", + "\u0e27\u0e31\u0e19\u0e1e\u0e24\u0e2b\u0e31\u0e2a\u0e1a\u0e14\u0e35", + "\u0e27\u0e31\u0e19\u0e28\u0e38\u0e01\u0e23\u0e4c", + "\u0e27\u0e31\u0e19\u0e40\u0e2a\u0e32\u0e23\u0e4c", + }; + + final String[] sharedDayNarrows = { + "\u0e2d\u0e32", + "\u0e08", + "\u0e2d", + "\u0e1e", + "\u0e1e\u0e24", + "\u0e28", + "\u0e2a", + }; + + final String[] sharedEras = { + "", + "\u0e2e.\u0e28.", + }; + + final String[] sharedTimePatterns = { + "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 zzzz", + "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 z", + "HH:mm:ss", + "HH:mm", + }; + + final String[] sharedNarrowAmPmMarkers = { + "a", + "p", + }; + + final String[] sharedJavaTimeLongEras = { + "\u0e04.\u0e28.", + "\u0e40\u0e21\u0e08\u0e34", + "\u0e17\u0e30\u0e2d\u0e34\u0e42\u0e0a", + "\u0e42\u0e0a\u0e27\u0e30", + "\u0e40\u0e2e\u0e40\u0e0b", + }; + + final String[] sharedShortEras = { + "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", + "\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", + }; + + final String[] sharedMonthNarrows = { + "\u0e21.\u0e04.", + "\u0e01.\u0e1e.", + "\u0e21\u0e35.\u0e04.", + "\u0e40\u0e21.\u0e22.", + "\u0e1e.\u0e04.", + "\u0e21\u0e34.\u0e22.", + "\u0e01.\u0e04.", + "\u0e2a.\u0e04.", + "\u0e01.\u0e22.", + "\u0e15.\u0e04.", + "\u0e1e.\u0e22.", + "\u0e18.\u0e04.", + "", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, + sharedQuarterNames }, { "QuarterNames", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0e1b\u0e0f\u0e34\u0e17\u0e34\u0e19\u0e1e\u0e38\u0e17\u0e18" }, { "calendarname.gregorian", @@ -126,11 +202,7 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { { "field.zone", "\u0e40\u0e02\u0e15\u0e40\u0e27\u0e25\u0e32" }, { "islamic.AmPmMarkers", - new String[] { - "\u0e01\u0e48\u0e2d\u0e19\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - "\u0e2b\u0e25\u0e31\u0e07\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE\u0e17\u0e35\u0e48 d MMMM GGGG y", @@ -140,44 +212,13 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "\u0e2d\u0e32.", - "\u0e08.", - "\u0e2d.", - "\u0e1e.", - "\u0e1e\u0e24.", - "\u0e28.", - "\u0e2a.", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u0e27\u0e31\u0e19\u0e2d\u0e32\u0e17\u0e34\u0e15\u0e22\u0e4c", - "\u0e27\u0e31\u0e19\u0e08\u0e31\u0e19\u0e17\u0e23\u0e4c", - "\u0e27\u0e31\u0e19\u0e2d\u0e31\u0e07\u0e04\u0e32\u0e23", - "\u0e27\u0e31\u0e19\u0e1e\u0e38\u0e18", - "\u0e27\u0e31\u0e19\u0e1e\u0e24\u0e2b\u0e31\u0e2a\u0e1a\u0e14\u0e35", - "\u0e27\u0e31\u0e19\u0e28\u0e38\u0e01\u0e23\u0e4c", - "\u0e27\u0e31\u0e19\u0e40\u0e2a\u0e32\u0e23\u0e4c", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u0e2d\u0e32", - "\u0e08", - "\u0e2d", - "\u0e1e", - "\u0e1e\u0e24", - "\u0e28", - "\u0e2a", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "\u0e2e.\u0e28.", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", new String[] { "\u0e21\u0e38\u0e2e\u0e31\u0e23.", @@ -213,43 +254,13 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, + sharedQuarterNames }, { "islamic.QuarterNames", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 zzzz", - "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u0e01\u0e48\u0e2d\u0e19\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - "\u0e2b\u0e25\u0e31\u0e07\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", new String[] { "", @@ -257,23 +268,11 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "islamic.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "\u0e2e.\u0e28.", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u0e2e.\u0e28.", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", new String[] { "EEEE\u0e17\u0e35\u0e48 d MMMM G y", @@ -311,23 +310,9 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "\u0e04.\u0e28.", - "\u0e40\u0e21\u0e08\u0e34", - "\u0e17\u0e30\u0e2d\u0e34\u0e42\u0e0a", - "\u0e42\u0e0a\u0e27\u0e30", - "\u0e40\u0e2e\u0e40\u0e0b", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.short.Eras", - new String[] { - "\u0e04.\u0e28.", - "\u0e40\u0e21\u0e08\u0e34", - "\u0e17\u0e30\u0e2d\u0e34\u0e42\u0e0a", - "\u0e42\u0e0a\u0e27\u0e30", - "\u0e40\u0e2e\u0e40\u0e0b", - } - }, + sharedJavaTimeLongEras }, { "java.time.long.Eras", new String[] { "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e04\u0e23\u0e34\u0e2a\u0e15\u0e4c\u0e28\u0e31\u0e01\u0e23\u0e32\u0e0a", @@ -349,11 +334,7 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u0e01\u0e48\u0e2d\u0e19\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - "\u0e2b\u0e25\u0e31\u0e07\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "EEEE\u0e17\u0e35\u0e48 d MMMM \u0e1b\u0e35GGGG\u0e17\u0e35\u0e48 y", @@ -363,61 +344,15 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "\u0e2d\u0e32.", - "\u0e08.", - "\u0e2d.", - "\u0e1e.", - "\u0e1e\u0e24.", - "\u0e28.", - "\u0e2a.", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u0e27\u0e31\u0e19\u0e2d\u0e32\u0e17\u0e34\u0e15\u0e22\u0e4c", - "\u0e27\u0e31\u0e19\u0e08\u0e31\u0e19\u0e17\u0e23\u0e4c", - "\u0e27\u0e31\u0e19\u0e2d\u0e31\u0e07\u0e04\u0e32\u0e23", - "\u0e27\u0e31\u0e19\u0e1e\u0e38\u0e18", - "\u0e27\u0e31\u0e19\u0e1e\u0e24\u0e2b\u0e31\u0e2a\u0e1a\u0e14\u0e35", - "\u0e27\u0e31\u0e19\u0e28\u0e38\u0e01\u0e23\u0e4c", - "\u0e27\u0e31\u0e19\u0e40\u0e2a\u0e32\u0e23\u0e4c", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u0e2d\u0e32", - "\u0e08", - "\u0e2d", - "\u0e1e", - "\u0e1e\u0e24", - "\u0e28", - "\u0e2a", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - "\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", - new String[] { - "\u0e21.\u0e04.", - "\u0e01.\u0e1e.", - "\u0e21\u0e35.\u0e04.", - "\u0e40\u0e21.\u0e22.", - "\u0e1e.\u0e04.", - "\u0e21\u0e34.\u0e22.", - "\u0e01.\u0e04.", - "\u0e2a.\u0e04.", - "\u0e01.\u0e22.", - "\u0e15.\u0e04.", - "\u0e1e.\u0e22.", - "\u0e18.\u0e04.", - "", - } - }, + sharedMonthNarrows }, { "roc.MonthNames", new String[] { "\u0e21\u0e01\u0e23\u0e32\u0e04\u0e21", @@ -436,76 +371,23 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { } }, { "roc.MonthNarrows", - new String[] { - "\u0e21.\u0e04.", - "\u0e01.\u0e1e.", - "\u0e21\u0e35.\u0e04.", - "\u0e40\u0e21.\u0e22.", - "\u0e1e.\u0e04.", - "\u0e21\u0e34.\u0e22.", - "\u0e01.\u0e04.", - "\u0e2a.\u0e04.", - "\u0e01.\u0e22.", - "\u0e15.\u0e04.", - "\u0e1e.\u0e22.", - "\u0e18.\u0e04.", - "", - } - }, + sharedMonthNarrows }, { "roc.QuarterAbbreviations", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, + sharedQuarterNames }, { "roc.QuarterNames", - new String[] { - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 1", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 2", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 3", - "\u0e44\u0e15\u0e23\u0e21\u0e32\u0e2a 4", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 zzzz", - "H \u0e19\u0e32\u0e2c\u0e34\u0e01\u0e32 mm \u0e19\u0e32\u0e17\u0e35 ss \u0e27\u0e34\u0e19\u0e32\u0e17\u0e35 z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u0e01\u0e48\u0e2d\u0e19\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - "\u0e2b\u0e25\u0e31\u0e07\u0e40\u0e17\u0e35\u0e48\u0e22\u0e07", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - "\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "a", - "p", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - "\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "\u0e1b\u0e35\u0e01\u0e48\u0e2d\u0e19\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - "\u0e44\u0e15\u0e49\u0e2b\u0e27\u0e31\u0e19", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_tr.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_tr.java index 3868b04864f..2ebe20fdc5b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_tr.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_tr.java @@ -72,31 +72,114 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_tr extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "\u00c71", + "\u00c72", + "\u00c73", + "\u00c74", + }; + + final String[] sharedQuarterNames = { + "1. \u00e7eyrek", + "2. \u00e7eyrek", + "3. \u00e7eyrek", + "4. \u00e7eyrek", + }; + + final String[] sharedQuarterNarrows = { + "1.", + "2.", + "3.", + "4.", + }; + + final String[] sharedAmPmMarkers = { + "\u00d6\u00d6", + "\u00d6S", + }; + + final String[] sharedDatePatterns = { + "GGGG d MMMM y EEEE", + "GGGG d MMMM y", + "GGGG d MMM y", + "G d.MM.y", + }; + + final String[] sharedDayAbbreviations = { + "Paz", + "Pzt", + "Sal", + "\u00c7ar", + "Per", + "Cum", + "Cmt", + }; + + final String[] sharedDayNames = { + "Pazar", + "Pazartesi", + "Sal\u0131", + "\u00c7ar\u015famba", + "Per\u015fembe", + "Cuma", + "Cumartesi", + }; + + final String[] sharedDayNarrows = { + "P", + "P", + "S", + "\u00c7", + "P", + "C", + "C", + }; + + final String[] sharedEras = { + "", + "Hicri", + }; + + final String[] sharedMonthNames = { + "Muharrem", + "Safer", + "Rebi\u00fclevvel", + "Rebi\u00fclahir", + "Cemaziyelevvel", + "Cemaziyelahir", + "Recep", + "\u015eaban", + "Ramazan", + "\u015eevval", + "Zilkade", + "Zilhicce", + "", + }; + + final String[] sharedNarrowAmPmMarkers = { + "\u00f6\u00f6", + "\u00f6s", + }; + + final String[] sharedJavaTimeDatePatterns = { + "G d MMMM y EEEE", + "G d MMMM y", + "G d MMM y", + "GGGGG d.MM.y", + }; + + final String[] sharedShortEras = { + "Before R.O.C.", + "Minguo", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "\u00c71", - "\u00c72", - "\u00c73", - "\u00c74", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1. \u00e7eyrek", - "2. \u00e7eyrek", - "3. \u00e7eyrek", - "4. \u00e7eyrek", - } - }, + sharedQuarterNames }, { "QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, + sharedQuarterNarrows }, { "calendarname.buddhist", "Budist Takvimi" }, { "calendarname.gregorian", @@ -134,168 +217,39 @@ public class JavaTimeSupplementary_tr extends OpenListResourceBundle { { "field.zone", "Saat Dilimi" }, { "islamic.AmPmMarkers", - new String[] { - "\u00d6\u00d6", - "\u00d6S", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "GGGG d MMMM y EEEE", - "GGGG d MMMM y", - "GGGG d MMM y", - "G d.MM.y", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "Paz", - "Pzt", - "Sal", - "\u00c7ar", - "Per", - "Cum", - "Cmt", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Pazar", - "Pazartesi", - "Sal\u0131", - "\u00c7ar\u015famba", - "Per\u015fembe", - "Cuma", - "Cumartesi", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "P", - "P", - "S", - "\u00c7", - "P", - "C", - "C", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "Hicri", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", - new String[] { - "Muharrem", - "Safer", - "Rebi\u00fclevvel", - "Rebi\u00fclahir", - "Cemaziyelevvel", - "Cemaziyelahir", - "Recep", - "\u015eaban", - "Ramazan", - "\u015eevval", - "Zilkade", - "Zilhicce", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNames", - new String[] { - "Muharrem", - "Safer", - "Rebi\u00fclevvel", - "Rebi\u00fclahir", - "Cemaziyelevvel", - "Cemaziyelahir", - "Recep", - "\u015eaban", - "Ramazan", - "\u015eevval", - "Zilkade", - "Zilhicce", - "", - } - }, + sharedMonthNames }, { "islamic.QuarterAbbreviations", - new String[] { - "\u00c71", - "\u00c72", - "\u00c73", - "\u00c74", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1. \u00e7eyrek", - "2. \u00e7eyrek", - "3. \u00e7eyrek", - "4. \u00e7eyrek", - } - }, + sharedQuarterNames }, { "islamic.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNarrows }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u00d6\u00d6", - "\u00d6S", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "Hicri", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u00f6\u00f6", - "\u00f6s", - } - }, + sharedNarrowAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "Hicri", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "Hicri", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", - new String[] { - "G d MMMM y EEEE", - "G d MMMM y", - "G d MMM y", - "GGGGG d.MM.y", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -303,13 +257,7 @@ public class JavaTimeSupplementary_tr extends OpenListResourceBundle { } }, { "java.time.islamic.DatePatterns", - new String[] { - "G d MMMM y EEEE", - "G d MMMM y", - "G d MMM y", - "GGGGG d.MM.y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", new String[] { "d MMMM y G EEEE", @@ -325,13 +273,7 @@ public class JavaTimeSupplementary_tr extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "G d MMMM y EEEE", - "G d MMMM y", - "G d MMM y", - "GGGGG d.MM.y", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "M\u00d6", @@ -339,58 +281,17 @@ public class JavaTimeSupplementary_tr extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u00d6\u00d6", - "\u00d6S", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "GGGG d MMMM y EEEE", - "GGGG d MMMM y", - "GGGG d MMM y", - "G d.MM.y", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "Paz", - "Pzt", - "Sal", - "\u00c7ar", - "Per", - "Cum", - "Cmt", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Pazar", - "Pazartesi", - "Sal\u0131", - "\u00c7ar\u015famba", - "Per\u015fembe", - "Cuma", - "Cumartesi", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "P", - "P", - "S", - "\u00c7", - "P", - "C", - "C", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", new String[] { "Oca", @@ -443,67 +344,21 @@ public class JavaTimeSupplementary_tr extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "\u00c71", - "\u00c72", - "\u00c73", - "\u00c74", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1. \u00e7eyrek", - "2. \u00e7eyrek", - "3. \u00e7eyrek", - "4. \u00e7eyrek", - } - }, + sharedQuarterNames }, { "roc.QuarterNarrows", - new String[] { - "1.", - "2.", - "3.", - "4.", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNarrows }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u00d6\u00d6", - "\u00d6S", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u00f6\u00f6", - "\u00f6s", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "Before R.O.C.", - "Minguo", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_uk.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_uk.java index feb55bdb6de..b3c0b2c841b 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_uk.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_uk.java @@ -72,23 +72,74 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_uk extends OpenListResourceBundle { @Override protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "1-\u0439 \u043a\u0432.", + "2-\u0439 \u043a\u0432.", + "3-\u0439 \u043a\u0432.", + "4-\u0439 \u043a\u0432.", + }; + + final String[] sharedQuarterNames = { + "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", + }; + + final String[] sharedAmPmMarkers = { + "\u0434\u043f", + "\u043f\u043f", + }; + + final String[] sharedDatePatterns = { + "EEEE, d MMMM y '\u0440'. GGGG", + "d MMMM y '\u0440'. GGGG", + "d MMM y GGGG", + "dd.MM.yy G", + }; + + final String[] sharedDayAbbreviations = { + "\u041d\u0434", + "\u041f\u043d", + "\u0412\u0442", + "\u0421\u0440", + "\u0427\u0442", + "\u041f\u0442", + "\u0421\u0431", + }; + + final String[] sharedDayNames = { + "\u043d\u0435\u0434\u0456\u043b\u044f", + "\u043f\u043e\u043d\u0435\u0434\u0456\u043b\u043e\u043a", + "\u0432\u0456\u0432\u0442\u043e\u0440\u043e\u043a", + "\u0441\u0435\u0440\u0435\u0434\u0430", + "\u0447\u0435\u0442\u0432\u0435\u0440", + "\u043f\u02bc\u044f\u0442\u043d\u0438\u0446\u044f", + "\u0441\u0443\u0431\u043e\u0442\u0430", + }; + + final String[] sharedDayNarrows = { + "\u041d", + "\u041f", + "\u0412", + "\u0421", + "\u0427", + "\u041f", + "\u0421", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, d MMMM y '\u0440'. G", + "d MMMM y '\u0440'. G", + "d MMM y G", + "dd.MM.yy GGGGG", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u0431\u0443\u0434\u0434\u0456\u0439\u0441\u044c\u043a\u0438\u0439 \u043a\u0430\u043b\u0435\u043d\u0434\u0430\u0440" }, { "calendarname.gregorian", @@ -124,52 +175,15 @@ public class JavaTimeSupplementary_uk extends OpenListResourceBundle { { "field.zone", "\u0447\u0430\u0441\u043e\u0432\u0438\u0439 \u043f\u043e\u044f\u0441" }, { "islamic.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. GGGG", - "d MMMM y '\u0440'. GGGG", - "d MMM y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "islamic.DayAbbreviations", - new String[] { - "\u041d\u0434", - "\u041f\u043d", - "\u0412\u0442", - "\u0421\u0440", - "\u0427\u0442", - "\u041f\u0442", - "\u0421\u0431", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u043d\u0435\u0434\u0456\u043b\u044f", - "\u043f\u043e\u043d\u0435\u0434\u0456\u043b\u043e\u043a", - "\u0432\u0456\u0432\u0442\u043e\u0440\u043e\u043a", - "\u0441\u0435\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0435\u0440", - "\u043f\u02bc\u044f\u0442\u043d\u0438\u0446\u044f", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u041d", - "\u041f", - "\u0412", - "\u0421", - "\u0427", - "\u041f", - "\u0421", - } - }, + sharedDayNarrows }, { "islamic.MonthNames", new String[] { "\u041c\u0443\u0445\u0430\u0440\u0440\u0430\u043c", @@ -188,73 +202,19 @@ public class JavaTimeSupplementary_uk extends OpenListResourceBundle { } }, { "islamic.QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. G", - "d MMMM y '\u0440'. G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.islamic.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. G", - "d MMMM y '\u0440'. G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.japanese.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. G", - "d MMMM y '\u0440'. G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.long.Eras", new String[] { "\u0434\u043e \u043d\u0430\u0448\u043e\u0457 \u0435\u0440\u0438", @@ -262,13 +222,7 @@ public class JavaTimeSupplementary_uk extends OpenListResourceBundle { } }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. G", - "d MMMM y '\u0440'. G", - "d MMM y G", - "dd.MM.yy GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", new String[] { "\u0434\u043e \u043d.\u0435.", @@ -276,52 +230,15 @@ public class JavaTimeSupplementary_uk extends OpenListResourceBundle { } }, { "roc.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", - new String[] { - "EEEE, d MMMM y '\u0440'. GGGG", - "d MMMM y '\u0440'. GGGG", - "d MMM y GGGG", - "dd.MM.yy G", - } - }, + sharedDatePatterns }, { "roc.DayAbbreviations", - new String[] { - "\u041d\u0434", - "\u041f\u043d", - "\u0412\u0442", - "\u0421\u0440", - "\u0427\u0442", - "\u041f\u0442", - "\u0421\u0431", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u043d\u0435\u0434\u0456\u043b\u044f", - "\u043f\u043e\u043d\u0435\u0434\u0456\u043b\u043e\u043a", - "\u0432\u0456\u0432\u0442\u043e\u0440\u043e\u043a", - "\u0441\u0435\u0440\u0435\u0434\u0430", - "\u0447\u0435\u0442\u0432\u0435\u0440", - "\u043f\u02bc\u044f\u0442\u043d\u0438\u0446\u044f", - "\u0441\u0443\u0431\u043e\u0442\u0430", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u041d", - "\u041f", - "\u0412", - "\u0421", - "\u0427", - "\u041f", - "\u0421", - } - }, + sharedDayNarrows }, { "roc.MonthAbbreviations", new String[] { "\u0441\u0456\u0447.", @@ -374,41 +291,13 @@ public class JavaTimeSupplementary_uk extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1-\u0439 \u043a\u0432.", - "2-\u0439 \u043a\u0432.", - "3-\u0439 \u043a\u0432.", - "4-\u0439 \u043a\u0432.", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "1-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "2-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "3-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - "4-\u0439 \u043a\u0432\u0430\u0440\u0442\u0430\u043b", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u0434\u043f", - "\u043f\u043f", - } - }, + sharedAmPmMarkers }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_vi.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_vi.java index f023d9312dc..662391c46b6 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_vi.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_vi.java @@ -72,19 +72,80 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_vi extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterNames = { + "Qu\u00fd 1", + "Qu\u00fd 2", + "Qu\u00fd 3", + "Qu\u00fd 4", + }; + + final String[] sharedAmPmMarkers = { + "SA", + "CH", + }; + + final String[] sharedDayAbbreviations = { + "CN", + "Th 2", + "Th 3", + "Th 4", + "Th 5", + "Th 6", + "Th 7", + }; + + final String[] sharedDayNames = { + "Ch\u1ee7 Nh\u1eadt", + "Th\u1ee9 Hai", + "Th\u1ee9 Ba", + "Th\u1ee9 T\u01b0", + "Th\u1ee9 N\u0103m", + "Th\u1ee9 S\u00e1u", + "Th\u1ee9 B\u1ea3y", + }; + + final String[] sharedDayNarrows = { + "CN", + "T2", + "T3", + "T4", + "T5", + "T6", + "T7", + }; + + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedNarrowAmPmMarkers = { + "s", + "c", + }; + + final String[] sharedJavaTimeDatePatterns = { + "EEEE, 'ng\u00e0y' dd MMMM 'n\u0103m' y G", + "'Ng\u00e0y' dd 'th\u00e1ng' M 'n\u0103m' y G", + "dd-MM-y G", + "dd/MM/y GGGGG", + }; + + final String[] sharedJavaTimeLongEras = { "tr. CN", "sau CN", }; + + final String[] sharedEras = { + "Tr\u01b0\u1edbc R.O.C", + "R.O.C.", + }; + return new Object[][] { { "QuarterNames", - new String[] { - "Qu\u00fd 1", - "Qu\u00fd 2", - "Qu\u00fd 3", - "Qu\u00fd 4", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "L\u1ecbch Ph\u1eadt Gi\u00e1o" }, { "calendarname.gregorian", @@ -122,11 +183,7 @@ public class JavaTimeSupplementary_vi extends OpenListResourceBundle { { "field.zone", "M\u00fai gi\u1edd" }, { "islamic.AmPmMarkers", - new String[] { - "SA", - "CH", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "EEEE, 'ng\u00e0y' dd 'th\u00e1ng' MM 'n\u0103m' y GGGG", @@ -136,120 +193,21 @@ public class JavaTimeSupplementary_vi extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "CN", - "Th 2", - "Th 3", - "Th 4", - "Th 5", - "Th 6", - "Th 7", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "Ch\u1ee7 Nh\u1eadt", - "Th\u1ee9 Hai", - "Th\u1ee9 Ba", - "Th\u1ee9 T\u01b0", - "Th\u1ee9 N\u0103m", - "Th\u1ee9 S\u00e1u", - "Th\u1ee9 B\u1ea3y", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "CN", - "T2", - "T3", - "T4", - "T5", - "T6", - "T7", - } - }, - { "islamic.Eras", - new String[] { - "", - "AH", - } - }, + sharedDayNarrows }, { "islamic.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "Qu\u00fd 1", - "Qu\u00fd 2", - "Qu\u00fd 3", - "Qu\u00fd 4", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, - { "islamic.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "SA", - "CH", - } - }, - { "islamic.long.Eras", - new String[] { - "", - "AH", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.AmPmMarkers", - new String[] { - "s", - "c", - } - }, - { "islamic.narrow.Eras", - new String[] { - "", - "AH", - } - }, - { "islamic.short.Eras", - new String[] { - "", - "AH", - } - }, + sharedNarrowAmPmMarkers }, { "java.time.buddhist.DatePatterns", - new String[] { - "EEEE, 'ng\u00e0y' dd MMMM 'n\u0103m' y G", - "'Ng\u00e0y' dd 'th\u00e1ng' M 'n\u0103m' y G", - "dd-MM-y G", - "dd/MM/y GGGGG", - } - }, - { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "BE", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.buddhist.short.Eras", new String[] { "BC", @@ -273,23 +231,13 @@ public class JavaTimeSupplementary_vi extends OpenListResourceBundle { } }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "java.time.roc.DatePatterns", - new String[] { - "EEEE, 'ng\u00e0y' dd MMMM 'n\u0103m' y G", - "'Ng\u00e0y' dd 'th\u00e1ng' M 'n\u0103m' y G", - "dd-MM-y G", - "dd/MM/y GGGGG", - } - }, + sharedJavaTimeDatePatterns }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeLongEras }, { "roc.AmPmMarkers", - new String[] { - "SA", - "CH", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "EEEE, 'ng\u00e0y' dd MMMM 'n\u0103m' y GGGG", @@ -299,44 +247,13 @@ public class JavaTimeSupplementary_vi extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "CN", - "Th 2", - "Th 3", - "Th 4", - "Th 5", - "Th 6", - "Th 7", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "Ch\u1ee7 Nh\u1eadt", - "Th\u1ee9 Hai", - "Th\u1ee9 Ba", - "Th\u1ee9 T\u01b0", - "Th\u1ee9 N\u0103m", - "Th\u1ee9 S\u00e1u", - "Th\u1ee9 B\u1ea3y", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "CN", - "T2", - "T3", - "T4", - "T5", - "T6", - "T7", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "Tr\u01b0\u1edbc R.O.C", - "R.O.C.", - } - }, + sharedEras }, { "roc.MonthAbbreviations", new String[] { "thg 1", @@ -371,77 +288,20 @@ public class JavaTimeSupplementary_vi extends OpenListResourceBundle { "", } }, - { "roc.MonthNarrows", - new String[] { - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "", - } - }, { "roc.QuarterAbbreviations", - new String[] { - "Q1", - "Q2", - "Q3", - "Q4", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "Qu\u00fd 1", - "Qu\u00fd 2", - "Qu\u00fd 3", - "Qu\u00fd 4", - } - }, - { "roc.TimePatterns", - new String[] { - "HH:mm:ss zzzz", - "HH:mm:ss z", - "HH:mm:ss", - "HH:mm", - } - }, + sharedQuarterNames }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "SA", - "CH", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "Tr\u01b0\u1edbc R.O.C", - "R.O.C.", - } - }, + sharedEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "s", - "c", - } - }, + sharedNarrowAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "Tr\u01b0\u1edbc R.O.C", - "R.O.C.", - } - }, + sharedEras }, { "roc.short.Eras", - new String[] { - "Tr\u01b0\u1edbc R.O.C", - "R.O.C.", - } - }, + sharedEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java index e1e19af2a14..147d2d8aa07 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java @@ -72,7 +72,61 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_zh extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] rocMonthAbbreviations = { + final String[] sharedQuarterAbbreviations = { + "1\u5b63\u5ea6", + "2\u5b63\u5ea6", + "3\u5b63\u5ea6", + "4\u5b63\u5ea6", + }; + + final String[] sharedQuarterNames = { + "\u7b2c\u4e00\u5b63\u5ea6", + "\u7b2c\u4e8c\u5b63\u5ea6", + "\u7b2c\u4e09\u5b63\u5ea6", + "\u7b2c\u56db\u5b63\u5ea6", + }; + + final String[] sharedAmPmMarkers = { + "\u4e0a\u5348", + "\u4e0b\u5348", + }; + + final String[] sharedDayAbbreviations = { + "\u5468\u65e5", + "\u5468\u4e00", + "\u5468\u4e8c", + "\u5468\u4e09", + "\u5468\u56db", + "\u5468\u4e94", + "\u5468\u516d", + }; + + final String[] sharedDayNames = { + "\u661f\u671f\u65e5", + "\u661f\u671f\u4e00", + "\u661f\u671f\u4e8c", + "\u661f\u671f\u4e09", + "\u661f\u671f\u56db", + "\u661f\u671f\u4e94", + "\u661f\u671f\u516d", + }; + + final String[] sharedDayNarrows = { + "\u65e5", + "\u4e00", + "\u4e8c", + "\u4e09", + "\u56db", + "\u4e94", + "\u516d", + }; + + final String[] sharedEras = { + "", + "\u4f0a\u65af\u5170\u5386", + }; + + final String[] sharedMonthAbbreviations = { "1\u6708", "2\u6708", "3\u6708", @@ -87,7 +141,8 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { "12\u6708", "", }; - final String[] rocMonthNames = { + + final String[] sharedMonthNames = { "\u4e00\u6708", "\u4e8c\u6708", "\u4e09\u6708", @@ -102,31 +157,42 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { "\u5341\u4e8c\u6708", "", }; - final String[] javatimebuddhistlongEras = { + + final String[] sharedTimePatterns = { + "zzzz ah:mm:ss", + "z ah:mm:ss", + "ah:mm:ss", + "ah:mm", + }; + + final String[] sharedJavaTimeLongEras = { "BC", "\u4f5b\u5386", }; - final String[] javatimelongEras = { + + final String[] sharedJavaTimeShortEras = { + "\u516c\u5143", + "\u660e\u6cbb", + "\u5927\u6b63", + "\u662d\u548c", + "\u5e73\u6210", + }; + + final String[] sharedJavaTimeShortEras2 = { "\u516c\u5143\u524d", "\u516c\u5143", }; + + final String[] sharedShortEras = { + "\u6c11\u56fd\u524d", + "\u6c11\u56fd", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1\u5b63\u5ea6", - "2\u5b63\u5ea6", - "3\u5b63\u5ea6", - "4\u5b63\u5ea6", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\u7b2c\u4e00\u5b63\u5ea6", - "\u7b2c\u4e8c\u5b63\u5ea6", - "\u7b2c\u4e09\u5b63\u5ea6", - "\u7b2c\u56db\u5b63\u5ea6", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u4f5b\u6559\u65e5\u5386" }, { "calendarname.gregorian", @@ -162,11 +228,7 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { { "field.zone", "\u65f6\u533a" }, { "islamic.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "islamic.DatePatterns", new String[] { "GGGGy\u5e74M\u6708d\u65e5EEEE", @@ -176,110 +238,33 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { } }, { "islamic.DayAbbreviations", - new String[] { - "\u5468\u65e5", - "\u5468\u4e00", - "\u5468\u4e8c", - "\u5468\u4e09", - "\u5468\u56db", - "\u5468\u4e94", - "\u5468\u516d", - } - }, + sharedDayAbbreviations }, { "islamic.DayNames", - new String[] { - "\u661f\u671f\u65e5", - "\u661f\u671f\u4e00", - "\u661f\u671f\u4e8c", - "\u661f\u671f\u4e09", - "\u661f\u671f\u56db", - "\u661f\u671f\u4e94", - "\u661f\u671f\u516d", - } - }, + sharedDayNames }, { "islamic.DayNarrows", - new String[] { - "\u65e5", - "\u4e00", - "\u4e8c", - "\u4e09", - "\u56db", - "\u4e94", - "\u516d", - } - }, + sharedDayNarrows }, { "islamic.Eras", - new String[] { - "", - "\u4f0a\u65af\u5170\u5386", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", - rocMonthAbbreviations }, + sharedMonthAbbreviations }, { "islamic.MonthNames", - rocMonthNames }, + sharedMonthNames }, { "islamic.QuarterAbbreviations", - new String[] { - "1\u5b63\u5ea6", - "2\u5b63\u5ea6", - "3\u5b63\u5ea6", - "4\u5b63\u5ea6", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u7b2c\u4e00\u5b63\u5ea6", - "\u7b2c\u4e8c\u5b63\u5ea6", - "\u7b2c\u4e09\u5b63\u5ea6", - "\u7b2c\u56db\u5b63\u5ea6", - } - }, - { "islamic.QuarterNarrows", - new String[] { - "1", - "2", - "3", - "4", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "zzzz ah:mm:ss", - "z ah:mm:ss", - "ah:mm:ss", - "ah:mm", - } - }, + sharedTimePatterns }, { "islamic.abbreviated.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "islamic.long.Eras", - new String[] { - "", - "\u4f0a\u65af\u5170\u5386", - } - }, + sharedEras }, { "islamic.narrow.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "islamic.narrow.Eras", - new String[] { - "", - "\u4f0a\u65af\u5170\u5386", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u4f0a\u65af\u5170\u5386", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5EEEE", @@ -289,9 +274,9 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { } }, { "java.time.buddhist.long.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - javatimebuddhistlongEras }, + sharedJavaTimeLongEras }, { "java.time.islamic.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5EEEE", @@ -309,25 +294,11 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "\u516c\u5143", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeShortEras }, { "java.time.japanese.short.Eras", - new String[] { - "\u516c\u5143", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeShortEras }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "java.time.roc.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5EEEE", @@ -337,13 +308,9 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { } }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "roc.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "roc.DatePatterns", new String[] { "GGGGy\u5e74M\u6708d\u65e5EEEE", @@ -353,119 +320,33 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "\u5468\u65e5", - "\u5468\u4e00", - "\u5468\u4e8c", - "\u5468\u4e09", - "\u5468\u56db", - "\u5468\u4e94", - "\u5468\u516d", - } - }, + sharedDayAbbreviations }, { "roc.DayNames", - new String[] { - "\u661f\u671f\u65e5", - "\u661f\u671f\u4e00", - "\u661f\u671f\u4e8c", - "\u661f\u671f\u4e09", - "\u661f\u671f\u56db", - "\u661f\u671f\u4e94", - "\u661f\u671f\u516d", - } - }, + sharedDayNames }, { "roc.DayNarrows", - new String[] { - "\u65e5", - "\u4e00", - "\u4e8c", - "\u4e09", - "\u56db", - "\u4e94", - "\u516d", - } - }, + sharedDayNarrows }, { "roc.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedShortEras }, { "roc.MonthAbbreviations", - rocMonthAbbreviations }, + sharedMonthAbbreviations }, { "roc.MonthNames", - rocMonthNames }, - { "roc.MonthNarrows", - new String[] { - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "", - } - }, + sharedMonthNames }, { "roc.QuarterAbbreviations", - new String[] { - "1\u5b63\u5ea6", - "2\u5b63\u5ea6", - "3\u5b63\u5ea6", - "4\u5b63\u5ea6", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u7b2c\u4e00\u5b63\u5ea6", - "\u7b2c\u4e8c\u5b63\u5ea6", - "\u7b2c\u4e09\u5b63\u5ea6", - "\u7b2c\u56db\u5b63\u5ea6", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "zzzz ah:mm:ss", - "z ah:mm:ss", - "ah:mm:ss", - "ah:mm", - } - }, + sharedTimePatterns }, { "roc.abbreviated.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "roc.long.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedShortEras }, { "roc.narrow.AmPmMarkers", - new String[] { - "\u4e0a\u5348", - "\u4e0b\u5348", - } - }, + sharedAmPmMarkers }, { "roc.narrow.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "\u6c11\u56fd\u524d", - "\u6c11\u56fd", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_HK.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_HK.java new file mode 100644 index 00000000000..ad2d99c33be --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_HK.java @@ -0,0 +1,123 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_zh_HK extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedQuarterAbbreviations = { + "Q1", + "Q2", + "Q3", + "Q4", + }; + + final String[] sharedJavaTimeDatePatterns = { + "Gy\u5e74M\u6708d\u65e5EEEE", + "Gy\u5e74M\u6708d\u65e5", + "Gy\u5e74M\u6708d\u65e5", + "Gy/M/d", + }; + + final String[] sharedJavaTimeLongEras = { + "\u516c\u5143\u524d", + "\u516c\u5143", + }; + + return new Object[][] { + { "QuarterAbbreviations", + sharedQuarterAbbreviations }, + { "field.week", + "\u661f\u671f" }, + { "field.weekday", + "\u661f\u671f\u5e7e" }, + { "islamic.QuarterAbbreviations", + sharedQuarterAbbreviations }, + { "java.time.japanese.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.long.Eras", + sharedJavaTimeLongEras }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.short.Eras", + sharedJavaTimeLongEras }, + { "roc.DatePatterns", + new String[] { + "GGGGy\u5e74M\u6708d\u65e5EEEE", + "GGGGy\u5e74M\u6708d\u65e5", + "GGGGy\u5e74M\u6708d\u65e5", + "GGGGy/M/d", + } + }, + { "roc.QuarterAbbreviations", + sharedQuarterAbbreviations }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_SG.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_SG.java new file mode 100644 index 00000000000..79e253ddbef --- /dev/null +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_SG.java @@ -0,0 +1,104 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * COPYRIGHT AND PERMISSION NOTICE + * + * Copyright (C) 1991-2016 Unicode, Inc. All rights reserved. + * Distributed under the Terms of Use in + * http://www.unicode.org/copyright.html. + * + * Permission is hereby granted, free of charge, to any person obtaining + * a copy of the Unicode data files and any associated documentation + * (the "Data Files") or Unicode software and any associated documentation + * (the "Software") to deal in the Data Files or Software + * without restriction, including without limitation the rights to use, + * copy, modify, merge, publish, distribute, and/or sell copies of + * the Data Files or Software, and to permit persons to whom the Data Files + * or Software are furnished to do so, provided that + * (a) this copyright and permission notice appear with all copies + * of the Data Files or Software, + * (b) this copyright and permission notice appear in associated + * documentation, and + * (c) there is clear notice in each modified Data File or in the Software + * as well as in the documentation associated with the Data File(s) or + * Software that the data or software has been modified. + * + * THE DATA FILES AND SOFTWARE ARE PROVIDED "AS IS", WITHOUT WARRANTY OF + * ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE + * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT OF THIRD PARTY RIGHTS. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS + * NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL + * DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + * PERFORMANCE OF THE DATA FILES OR SOFTWARE. + * + * Except as contained in this notice, the name of a copyright holder + * shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in these Data Files or Software without prior + * written authorization of the copyright holder. + */ + +// Note: this file has been generated by a tool. + +package sun.text.resources.ext; + +import sun.util.resources.OpenListResourceBundle; + +public class JavaTimeSupplementary_zh_SG extends OpenListResourceBundle { + @Override + protected final Object[][] getContents() { + final String[] sharedDatePatterns = { + "GGGGy\u5e74M\u6708d\u65e5EEEE", + "GGGGy\u5e74M\u6708d\u65e5", + "GGGGy\u5e74M\u6708d\u65e5", + "GGGGd/M/yy", + }; + + final String[] sharedJavaTimeDatePatterns = { + "Gy\u5e74M\u6708d\u65e5EEEE", + "Gy\u5e74M\u6708d\u65e5", + "Gy\u5e74M\u6708d\u65e5", + "Gd/M/yy", + }; + + return new Object[][] { + { "islamic.DatePatterns", + sharedDatePatterns }, + { "java.time.buddhist.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.islamic.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.japanese.DatePatterns", + sharedJavaTimeDatePatterns }, + { "java.time.roc.DatePatterns", + sharedJavaTimeDatePatterns }, + { "roc.DatePatterns", + sharedDatePatterns }, + }; + } +} diff --git a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java index c612ff70ecb..3c8a83d0323 100644 --- a/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java +++ b/jdk/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java @@ -72,27 +72,86 @@ import sun.util.resources.OpenListResourceBundle; public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { @Override protected final Object[][] getContents() { - final String[] javatimelongEras = { + final String[] sharedQuarterAbbreviations = { + "1\u5b63", + "2\u5b63", + "3\u5b63", + "4\u5b63", + }; + + final String[] sharedQuarterNames = { + "\u7b2c1\u5b63", + "\u7b2c2\u5b63", + "\u7b2c3\u5b63", + "\u7b2c4\u5b63", + }; + + final String[] sharedDayAbbreviations = { + "\u9031\u65e5", + "\u9031\u4e00", + "\u9031\u4e8c", + "\u9031\u4e09", + "\u9031\u56db", + "\u9031\u4e94", + "\u9031\u516d", + }; + + final String[] sharedEras = { + "", + "\u4f0a\u65af\u862d\u66c6", + }; + + final String[] sharedMonthNames = { + "\u7a46\u54c8\u862d\u59c6\u6708", + "\u8272\u6cd5\u723e\u6708", + "\u8cf4\u6bd4\u6708 I", + "\u8cf4\u6bd4\u6708 II", + "\u4e3b\u99ac\u9054\u6708 I", + "\u4e3b\u99ac\u9054\u6708 II", + "\u8cf4\u54f2\u535c\u6708", + "\u820d\u723e\u90a6\u6708", + "\u8cf4\u8cb7\u4e39\u6708", + "\u9583\u74e6\u9b6f\u6708", + "\u90fd\u723e\u5580\u723e\u5fb7\u6708", + "\u90fd\u723e\u9ed1\u54f2\u6708", + "", + }; + + final String[] sharedTimePatterns = { + "ah:mm:ss [zzzz]", + "ah:mm:ss [z]", + "ah:mm:ss", + "ah:mm", + }; + + final String[] sharedJavaTimeLongEras = { + "BC", + "\u4f5b\u66c6", + }; + + final String[] sharedJavaTimeShortEras = { + "\u897f\u5143", + "\u660e\u6cbb", + "\u5927\u6b63", + "\u662d\u548c", + "\u5e73\u6210", + }; + + final String[] sharedJavaTimeShortEras2 = { "\u897f\u5143\u524d", "\u897f\u5143", }; + + final String[] sharedShortEras = { + "\u6c11\u570b\u524d", + "\u6c11\u570b", + }; + return new Object[][] { { "QuarterAbbreviations", - new String[] { - "1\u5b63", - "2\u5b63", - "3\u5b63", - "4\u5b63", - } - }, + sharedQuarterAbbreviations }, { "QuarterNames", - new String[] { - "\u7b2c1\u5b63", - "\u7b2c2\u5b63", - "\u7b2c3\u5b63", - "\u7b2c4\u5b63", - } - }, + sharedQuarterNames }, { "calendarname.buddhist", "\u4f5b\u66c6" }, { "calendarname.gregorian", @@ -124,98 +183,25 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { { "field.zone", "\u6642\u5340" }, { "islamic.DayAbbreviations", - new String[] { - "\u9031\u65e5", - "\u9031\u4e00", - "\u9031\u4e8c", - "\u9031\u4e09", - "\u9031\u56db", - "\u9031\u4e94", - "\u9031\u516d", - } - }, + sharedDayAbbreviations }, { "islamic.Eras", - new String[] { - "", - "\u4f0a\u65af\u862d\u66c6", - } - }, + sharedEras }, { "islamic.MonthAbbreviations", - new String[] { - "\u7a46\u54c8\u862d\u59c6\u6708", - "\u8272\u6cd5\u723e\u6708", - "\u8cf4\u6bd4\u6708 I", - "\u8cf4\u6bd4\u6708 II", - "\u4e3b\u99ac\u9054\u6708 I", - "\u4e3b\u99ac\u9054\u6708 II", - "\u8cf4\u54f2\u535c\u6708", - "\u820d\u723e\u90a6\u6708", - "\u8cf4\u8cb7\u4e39\u6708", - "\u9583\u74e6\u9b6f\u6708", - "\u90fd\u723e\u5580\u723e\u5fb7\u6708", - "\u90fd\u723e\u9ed1\u54f2\u6708", - "", - } - }, + sharedMonthNames }, { "islamic.MonthNames", - new String[] { - "\u7a46\u54c8\u862d\u59c6\u6708", - "\u8272\u6cd5\u723e\u6708", - "\u8cf4\u6bd4\u6708 I", - "\u8cf4\u6bd4\u6708 II", - "\u4e3b\u99ac\u9054\u6708 I", - "\u4e3b\u99ac\u9054\u6708 II", - "\u8cf4\u54f2\u535c\u6708", - "\u820d\u723e\u90a6\u6708", - "\u8cf4\u8cb7\u4e39\u6708", - "\u9583\u74e6\u9b6f\u6708", - "\u90fd\u723e\u5580\u723e\u5fb7\u6708", - "\u90fd\u723e\u9ed1\u54f2\u6708", - "", - } - }, + sharedMonthNames }, { "islamic.QuarterAbbreviations", - new String[] { - "1\u5b63", - "2\u5b63", - "3\u5b63", - "4\u5b63", - } - }, + sharedQuarterAbbreviations }, { "islamic.QuarterNames", - new String[] { - "\u7b2c1\u5b63", - "\u7b2c2\u5b63", - "\u7b2c3\u5b63", - "\u7b2c4\u5b63", - } - }, + sharedQuarterNames }, { "islamic.TimePatterns", - new String[] { - "ah:mm:ss [zzzz]", - "ah:mm:ss [z]", - "ah:mm:ss", - "ah:mm", - } - }, + sharedTimePatterns }, { "islamic.long.Eras", - new String[] { - "", - "\u4f0a\u65af\u862d\u66c6", - } - }, + sharedEras }, { "islamic.narrow.Eras", - new String[] { - "", - "\u4f0a\u65af\u862d\u66c6", - } - }, + sharedEras }, { "islamic.short.Eras", - new String[] { - "", - "\u4f0a\u65af\u862d\u66c6", - } - }, + sharedEras }, { "java.time.buddhist.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5EEEE", @@ -225,17 +211,9 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { } }, { "java.time.buddhist.long.Eras", - new String[] { - "BC", - "\u4f5b\u66c6", - } - }, + sharedJavaTimeLongEras }, { "java.time.buddhist.short.Eras", - new String[] { - "BC", - "\u4f5b\u66c6", - } - }, + sharedJavaTimeLongEras }, { "java.time.japanese.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5EEEE", @@ -245,25 +223,11 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { } }, { "java.time.japanese.long.Eras", - new String[] { - "\u897f\u5143", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeShortEras }, { "java.time.japanese.short.Eras", - new String[] { - "\u897f\u5143", - "\u660e\u6cbb", - "\u5927\u6b63", - "\u662d\u548c", - "\u5e73\u6210", - } - }, + sharedJavaTimeShortEras }, { "java.time.long.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "java.time.roc.DatePatterns", new String[] { "Gy\u5e74M\u6708d\u65e5 EEEE", @@ -273,7 +237,7 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { } }, { "java.time.short.Eras", - javatimelongEras }, + sharedJavaTimeShortEras2 }, { "roc.DatePatterns", new String[] { "GGGGy\u5e74M\u6708d\u65e5 EEEE", @@ -283,22 +247,9 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { } }, { "roc.DayAbbreviations", - new String[] { - "\u9031\u65e5", - "\u9031\u4e00", - "\u9031\u4e8c", - "\u9031\u4e09", - "\u9031\u56db", - "\u9031\u4e94", - "\u9031\u516d", - } - }, + sharedDayAbbreviations }, { "roc.Eras", - new String[] { - "\u6c11\u570b\u524d", - "\u6c11\u570b", - } - }, + sharedShortEras }, { "roc.MonthNames", new String[] { "1\u6708", @@ -317,47 +268,17 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { } }, { "roc.QuarterAbbreviations", - new String[] { - "1\u5b63", - "2\u5b63", - "3\u5b63", - "4\u5b63", - } - }, + sharedQuarterAbbreviations }, { "roc.QuarterNames", - new String[] { - "\u7b2c1\u5b63", - "\u7b2c2\u5b63", - "\u7b2c3\u5b63", - "\u7b2c4\u5b63", - } - }, + sharedQuarterNames }, { "roc.TimePatterns", - new String[] { - "ah:mm:ss [zzzz]", - "ah:mm:ss [z]", - "ah:mm:ss", - "ah:mm", - } - }, + sharedTimePatterns }, { "roc.long.Eras", - new String[] { - "\u6c11\u570b\u524d", - "\u6c11\u570b", - } - }, + sharedShortEras }, { "roc.narrow.Eras", - new String[] { - "\u6c11\u570b\u524d", - "\u6c11\u570b", - } - }, + sharedShortEras }, { "roc.short.Eras", - new String[] { - "\u6c11\u570b\u524d", - "\u6c11\u570b", - } - }, + sharedShortEras }, }; } } diff --git a/jdk/test/sun/text/resources/JavaTimeSupplementaryTest.java b/jdk/test/sun/text/resources/JavaTimeSupplementaryTest.java new file mode 100644 index 00000000000..46a7bfc854f --- /dev/null +++ b/jdk/test/sun/text/resources/JavaTimeSupplementaryTest.java @@ -0,0 +1,153 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8159943 + * @modules java.base/sun.util.locale.provider + * java.base/sun.util.resources + * jdk.localedata + * @summary Test for checking consistency between CLDR and COMPAT locale data + * for java.time. + */ + +import java.util.Arrays; +import java.util.HashMap; +import java.util.List; +import java.util.Locale; +import java.util.Map; +import java.util.Objects; +import java.util.ResourceBundle; +import java.util.Set; +import java.util.TreeSet; +import java.util.stream.Collectors; +import sun.util.locale.provider.LocaleProviderAdapter.Type; +import sun.util.locale.provider.LocaleProviderAdapter; + +public class JavaTimeSupplementaryTest { + // COMPAT-to-CLDR locale mapping + private static final Map LOCALEMAP; + static { + LOCALEMAP = new HashMap<>(); + LOCALEMAP.put(new Locale("hi", "IN"), new Locale("hi")); + LOCALEMAP.put(new Locale("no", "NO", "NY"), new Locale("nn", "NO")); + LOCALEMAP.put(new Locale("no"), new Locale("nb")); + LOCALEMAP.put(Locale.TAIWAN, Locale.forLanguageTag("zh-Hant")); + LOCALEMAP.put(new Locale("zh", "HK"), Locale.forLanguageTag("zh-Hant-HK")); + LOCALEMAP.put(new Locale("zh", "SG"), Locale.forLanguageTag("zh-Hans-SG")); + LOCALEMAP.put(new Locale("sr", "BA"), Locale.forLanguageTag("sr-Cyrl-BA")); + } + + private static final String[] PREFIXES = { + "Quarter", + "java.time.", + "calendarname.", + "field.", + "islamic.", + "roc.", + }; + + // All available locales for the COMPAT FormatData resource bundles + static final List COMPAT_LOCALES + = Arrays.asList(LocaleProviderAdapter.forJRE() + .getDateFormatSymbolsProvider().getAvailableLocales()); + + static int errors; + + public static void main(String... args) { + for (Locale locale : COMPAT_LOCALES) { + ResourceBundle compat + = LocaleProviderAdapter.forJRE() + .getLocaleResources(locale).getJavaTimeFormatData(); + if (!compat.getLocale().equals(locale)) { + continue; + } + Locale cldrLocale = toCldrLocale(locale); + ResourceBundle cldr + = LocaleProviderAdapter.forType(Type.CLDR) + .getLocaleResources(locale).getJavaTimeFormatData(); + if (!cldr.getLocale().equals(cldrLocale)) { + continue; + } + compareResources(compat, cldr); + } + if (errors > 0) { + throw new RuntimeException(errors + " failure(s)"); + } + } + + private static Locale toCldrLocale(Locale compatLocale) { + Locale loc = LOCALEMAP.get(compatLocale); + return loc != null ? loc: compatLocale; + } + + private static void compareResources(ResourceBundle compat, ResourceBundle cldr) { + Set supplementalKeys = getSupplementalKeys(compat); + for (String key : supplementalKeys) { + Object compatData = compat.getObject(key); + String cldrKey = toCldrKey(key); + Object cldrData = cldr.containsKey(cldrKey) ? cldr.getObject(cldrKey) : null; + if (!Objects.deepEquals(compatData, cldrData)) { + // OK if key is for the Buddhist or Japanese calendars which had been + // supported before java.time, or if key is "java.time.short.Eras" due + // to legacy era names. + if (!(key.contains("buddhist") || key.contains("japanese") + || key.equals("java.time.short.Eras"))) { + errors++; + System.out.print("Failure: "); + } + System.out.println("diff: " + compat.getLocale().toLanguageTag() + "\n" + + " COMPAT: " + key + " -> " + toString(compatData) + "\n" + + " CLDR: " + cldrKey + " -> " + toString(cldrData)); + } + } + } + + private static Set getSupplementalKeys(ResourceBundle rb) { + // Collect keys starting with any of PREFIXES + Set keys = rb.keySet().stream() + .filter(k -> Arrays.stream(PREFIXES).anyMatch(p -> k.startsWith(p))) + .collect(Collectors.toCollection(TreeSet::new)); + return keys; + } + + /** + * Removes "java.time." prefix where it's unused in CLDR. + */ + private static String toCldrKey(String key) { + if (key.contains("short.Eras")) { + key = key.replace("short.", ""); + } + if (key.startsWith("java.time.") && key.endsWith(".Eras")) { + return key.substring("java.time.".length()); + } + return key; + } + + private static String toString(Object data) { + if (data instanceof String[]) { + return Arrays.toString((String[]) data); + } + return data.toString(); + } +} From a06c5e0f57135760f8969311c0290587b435f0c3 Mon Sep 17 00:00:00 2001 From: Michael Haupt Date: Mon, 4 Jul 2016 10:08:18 +0200 Subject: [PATCH 121/125] 8143211: provide bytecode intrinsics for loop and try/finally executors Reviewed-by: psandoz, redestad, vlivanov --- .../java/lang/invoke/BoundMethodHandle.java | 32 +- .../lang/invoke/InvokerBytecodeGenerator.java | 468 ++++++++++++++---- .../classes/java/lang/invoke/LambdaForm.java | 123 ++++- .../java/lang/invoke/LambdaFormBuffer.java | 4 +- .../java/lang/invoke/LambdaFormEditor.java | 41 +- .../classes/java/lang/invoke/MemberName.java | 17 +- .../java/lang/invoke/MethodHandleImpl.java | 437 ++++++++++------ .../java/lang/invoke/MethodHandles.java | 6 +- .../java/lang/invoke/MethodTypeForm.java | 10 +- .../java/lang/invoke/MethodHandlesTest.java | 2 +- 10 files changed, 843 insertions(+), 297 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/BoundMethodHandle.java b/jdk/src/java.base/share/classes/java/lang/invoke/BoundMethodHandle.java index 915dc89f4c8..a5db25507cb 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/BoundMethodHandle.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/BoundMethodHandle.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,17 +26,16 @@ package java.lang.invoke; import jdk.internal.loader.BootLoader; -import jdk.internal.vm.annotation.Stable; import jdk.internal.org.objectweb.asm.ClassWriter; import jdk.internal.org.objectweb.asm.FieldVisitor; import jdk.internal.org.objectweb.asm.MethodVisitor; +import jdk.internal.vm.annotation.Stable; import sun.invoke.util.ValueConversions; import sun.invoke.util.Wrapper; import java.lang.invoke.LambdaForm.NamedFunction; import java.lang.invoke.MethodHandles.Lookup; import java.lang.reflect.Field; -import java.util.Arrays; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; @@ -168,12 +167,16 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; } @Override - final Object internalValues() { - Object[] boundValues = new Object[speciesData().fieldCount()]; - for (int i = 0; i < boundValues.length; ++i) { - boundValues[i] = arg(i); + final String internalValues() { + int count = speciesData().fieldCount(); + if (count == 1) { + return "[" + arg(0) + "]"; } - return Arrays.asList(boundValues); + StringBuilder sb = new StringBuilder("["); + for (int i = 0; i < count; ++i) { + sb.append("\n ").append(i).append(": ( ").append(arg(i)).append(" )"); + } + return sb.append("\n]").toString(); } /*non-public*/ final Object arg(int i) { @@ -869,7 +872,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; */ static final SpeciesData SPECIES_DATA = SpeciesData.EMPTY; - private static final SpeciesData[] SPECIES_DATA_CACHE = new SpeciesData[5]; + private static final SpeciesData[] SPECIES_DATA_CACHE = new SpeciesData[6]; private static SpeciesData checkCache(int size, String types) { int idx = size - 1; SpeciesData data = SPECIES_DATA_CACHE[idx]; @@ -877,9 +880,10 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; SPECIES_DATA_CACHE[idx] = data = getSpeciesData(types); return data; } - static SpeciesData speciesData_L() { return checkCache(1, "L"); } - static SpeciesData speciesData_LL() { return checkCache(2, "LL"); } - static SpeciesData speciesData_LLL() { return checkCache(3, "LLL"); } - static SpeciesData speciesData_LLLL() { return checkCache(4, "LLLL"); } - static SpeciesData speciesData_LLLLL() { return checkCache(5, "LLLLL"); } + static SpeciesData speciesData_L() { return checkCache(1, "L"); } + static SpeciesData speciesData_LL() { return checkCache(2, "LL"); } + static SpeciesData speciesData_LLL() { return checkCache(3, "LLL"); } + static SpeciesData speciesData_LLLL() { return checkCache(4, "LLLL"); } + static SpeciesData speciesData_LLLLL() { return checkCache(5, "LLLLL"); } + static SpeciesData speciesData_LLLLLL() { return checkCache(6, "LLLLLL"); } } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java index da1700ffdb1..2df4c9d1f57 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java @@ -25,22 +25,30 @@ package java.lang.invoke; -import java.io.*; -import java.util.*; -import java.lang.reflect.Modifier; - -import jdk.internal.org.objectweb.asm.*; - -import static java.lang.invoke.LambdaForm.*; -import static java.lang.invoke.LambdaForm.BasicType.*; -import static java.lang.invoke.MethodHandleStatics.*; -import static java.lang.invoke.MethodHandleNatives.Constants.*; - +import jdk.internal.org.objectweb.asm.ClassWriter; +import jdk.internal.org.objectweb.asm.Label; +import jdk.internal.org.objectweb.asm.MethodVisitor; +import jdk.internal.org.objectweb.asm.Opcodes; +import jdk.internal.org.objectweb.asm.Type; import sun.invoke.util.VerifyAccess; import sun.invoke.util.VerifyType; import sun.invoke.util.Wrapper; import sun.reflect.misc.ReflectUtil; +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; +import java.lang.reflect.Modifier; +import java.util.Arrays; +import java.util.HashMap; +import java.util.Map; +import java.util.stream.Stream; + +import static java.lang.invoke.LambdaForm.*; +import static java.lang.invoke.LambdaForm.BasicType.*; +import static java.lang.invoke.MethodHandleNatives.Constants.*; +import static java.lang.invoke.MethodHandleStatics.*; + /** * Code generation backend for LambdaForm. *

    @@ -75,8 +83,8 @@ class InvokerBytecodeGenerator { private final MethodType invokerType; /** Info about local variables in compiled lambda form */ - private final int[] localsMap; // index - private final Class[] localClasses; // type + private int[] localsMap; // index + private Class[] localClasses; // type /** ASM bytecode generation. */ private ClassWriter cw; @@ -101,8 +109,7 @@ class InvokerBytecodeGenerator { this.lambdaForm = lambdaForm; this.invokerName = invokerName; this.invokerType = invokerType; - this.localsMap = new int[localsMapSize+1]; - // last entry of localsMap is count of allocated local slots + this.localsMap = new int[localsMapSize+1]; // last entry of localsMap is count of allocated local slots this.localClasses = new Class[localsMapSize+1]; } @@ -131,7 +138,6 @@ class InvokerBytecodeGenerator { } } - /** instance counters for dumped classes */ private static final HashMap DUMP_CLASS_FILES_COUNTERS; /** debugging flag for saving generated class files */ @@ -177,7 +183,6 @@ class InvokerBytecodeGenerator { } }); } - } private static String makeDumpableClassName(String className) { @@ -280,14 +285,11 @@ class InvokerBytecodeGenerator { private static MemberName resolveInvokerMember(Class invokerClass, String name, MethodType type) { MemberName member = new MemberName(invokerClass, name, type, REF_invokeStatic); - //System.out.println("resolveInvokerMember => "+member); - //for (Method m : invokerClass.getDeclaredMethods()) System.out.println(" "+m); try { member = MEMBERNAME_FACTORY.resolveOrFail(REF_invokeStatic, member, HOST_CLASS, ReflectiveOperationException.class); } catch (ReflectiveOperationException e) { throw newInternalError(e); } - //System.out.println("resolveInvokerMember => "+member); return member; } @@ -541,11 +543,12 @@ class InvokerBytecodeGenerator { Name writeBack = null; // local to write back result if (arg instanceof Name) { Name n = (Name) arg; - if (assertStaticType(cls, n)) - return; // this cast was already performed if (lambdaForm.useCount(n) > 1) { // This guy gets used more than once. writeBack = n; + if (assertStaticType(cls, n)) { + return; // this cast was already performed + } } } if (isStaticallyNameable(cls)) { @@ -679,19 +682,29 @@ class InvokerBytecodeGenerator { MethodHandleImpl.Intrinsic intr = name.function.intrinsicName(); switch (intr) { case SELECT_ALTERNATIVE: - assert isSelectAlternative(i); + assert lambdaForm.isSelectAlternative(i); if (PROFILE_GWT) { assert(name.arguments[0] instanceof Name && - nameRefersTo((Name)name.arguments[0], MethodHandleImpl.class, "profileBoolean")); + ((Name)name.arguments[0]).refersTo(MethodHandleImpl.class, "profileBoolean")); mv.visitAnnotation(INJECTEDPROFILE_SIG, true); } onStack = emitSelectAlternative(name, lambdaForm.names[i+1]); i++; // skip MH.invokeBasic of the selectAlternative result continue; case GUARD_WITH_CATCH: - assert isGuardWithCatch(i); + assert lambdaForm.isGuardWithCatch(i); onStack = emitGuardWithCatch(i); - i = i+2; // Jump to the end of GWC idiom + i += 2; // jump to the end of GWC idiom + continue; + case TRY_FINALLY: + assert lambdaForm.isTryFinally(i); + onStack = emitTryFinally(i); + i += 2; // jump to the end of the TF idiom + continue; + case LOOP: + assert lambdaForm.isLoop(i); + onStack = emitLoop(i); + i += 2; // jump to the end of the LOOP idiom continue; case NEW_ARRAY: Class rtype = name.function.methodType().returnType(); @@ -763,7 +776,7 @@ class InvokerBytecodeGenerator { * Emit an invoke for the given name. */ void emitInvoke(Name name) { - assert(!isLinkerMethodInvoke(name)); // should use the static path for these + assert(!name.isLinkerMethodInvoke()); // should use the static path for these if (true) { // push receiver MethodHandle target = name.function.resolvedHandle(); @@ -951,84 +964,6 @@ class InvokerBytecodeGenerator { throw new InternalError("refKind="+refKind); } - /** - * Check if MemberName is a call to a method named {@code name} in class {@code declaredClass}. - */ - private boolean memberRefersTo(MemberName member, Class declaringClass, String name) { - return member != null && - member.getDeclaringClass() == declaringClass && - member.getName().equals(name); - } - private boolean nameRefersTo(Name name, Class declaringClass, String methodName) { - return name.function != null && - memberRefersTo(name.function.member(), declaringClass, methodName); - } - - /** - * Check if MemberName is a call to MethodHandle.invokeBasic. - */ - private boolean isInvokeBasic(Name name) { - if (name.function == null) - return false; - if (name.arguments.length < 1) - return false; // must have MH argument - MemberName member = name.function.member(); - return memberRefersTo(member, MethodHandle.class, "invokeBasic") && - !member.isPublic() && !member.isStatic(); - } - - /** - * Check if MemberName is a call to MethodHandle.linkToStatic, etc. - */ - private boolean isLinkerMethodInvoke(Name name) { - if (name.function == null) - return false; - if (name.arguments.length < 1) - return false; // must have MH argument - MemberName member = name.function.member(); - return member != null && - member.getDeclaringClass() == MethodHandle.class && - !member.isPublic() && member.isStatic() && - member.getName().startsWith("linkTo"); - } - - /** - * Check if i-th name is a call to MethodHandleImpl.selectAlternative. - */ - private boolean isSelectAlternative(int pos) { - // selectAlternative idiom: - // t_{n}:L=MethodHandleImpl.selectAlternative(...) - // t_{n+1}:?=MethodHandle.invokeBasic(t_{n}, ...) - if (pos+1 >= lambdaForm.names.length) return false; - Name name0 = lambdaForm.names[pos]; - Name name1 = lambdaForm.names[pos+1]; - return nameRefersTo(name0, MethodHandleImpl.class, "selectAlternative") && - isInvokeBasic(name1) && - name1.lastUseIndex(name0) == 0 && // t_{n+1}:?=MethodHandle.invokeBasic(t_{n}, ...) - lambdaForm.lastUseIndex(name0) == pos+1; // t_{n} is local: used only in t_{n+1} - } - - /** - * Check if i-th name is a start of GuardWithCatch idiom. - */ - private boolean isGuardWithCatch(int pos) { - // GuardWithCatch idiom: - // t_{n}:L=MethodHandle.invokeBasic(...) - // t_{n+1}:L=MethodHandleImpl.guardWithCatch(*, *, *, t_{n}); - // t_{n+2}:?=MethodHandle.invokeBasic(t_{n+1}) - if (pos+2 >= lambdaForm.names.length) return false; - Name name0 = lambdaForm.names[pos]; - Name name1 = lambdaForm.names[pos+1]; - Name name2 = lambdaForm.names[pos+2]; - return nameRefersTo(name1, MethodHandleImpl.class, "guardWithCatch") && - isInvokeBasic(name0) && - isInvokeBasic(name2) && - name1.lastUseIndex(name0) == 3 && // t_{n+1}:L=MethodHandleImpl.guardWithCatch(*, *, *, t_{n}); - lambdaForm.lastUseIndex(name0) == pos+1 && // t_{n} is local: used only in t_{n+1} - name2.lastUseIndex(name1) == 1 && // t_{n+2}:?=MethodHandle.invokeBasic(t_{n+1}) - lambdaForm.lastUseIndex(name1) == pos+2; // t_{n+1} is local: used only in t_{n+2} - } - /** * Emit bytecode for the selectAlternative idiom. * @@ -1155,6 +1090,329 @@ class InvokerBytecodeGenerator { return result; } + /** + * Emit bytecode for the tryFinally idiom. + *

    + * The pattern looks like (Cf. MethodHandleImpl.makeTryFinally): + *

    {@code
    +     * // a0: BMH
    +     * // a1: target, a2: cleanup
    +     * // a3: box, a4: unbox
    +     * // a5 (and following): arguments
    +     * tryFinally=Lambda(a0:L,a1:L,a2:L,a3:L,a4:L,a5:L)=>{
    +     *   t6:L=MethodHandle.invokeBasic(a3:L,a5:L);         // box the arguments into an Object[]
    +     *   t7:L=MethodHandleImpl.tryFinally(a1:L,a2:L,t6:L); // call the tryFinally executor
    +     *   t8:L=MethodHandle.invokeBasic(a4:L,t7:L);t8:L}    // unbox the result; return the result
    +     * }
    + *

    + * It is compiled into bytecode equivalent to the following code: + *

    {@code
    +     * Throwable t;
    +     * Object r;
    +     * try {
    +     *     r = a1.invokeBasic(a5);
    +     * } catch (Throwable thrown) {
    +     *     t = thrown;
    +     *     throw t;
    +     * } finally {
    +     *     r = a2.invokeBasic(t, r, a5);
    +     * }
    +     * return r;
    +     * }
    + *

    + * Specifically, the bytecode will have the following form (the stack effects are given for the beginnings of + * blocks, and for the situations after executing the given instruction - the code will have a slightly different + * shape if the return type is {@code void}): + *

    {@code
    +     * TRY:                 (--)
    +     *                      load target                             (-- target)
    +     *                      load args                               (-- args... target)
    +     *                      INVOKEVIRTUAL MethodHandle.invokeBasic  (depends)
    +     * FINALLY_NORMAL:      (-- r)
    +     *                      load cleanup                            (-- cleanup r)
    +     *                      SWAP                                    (-- r cleanup)
    +     *                      ACONST_NULL                             (-- t r cleanup)
    +     *                      SWAP                                    (-- r t cleanup)
    +     *                      load args                               (-- args... r t cleanup)
    +     *                      INVOKEVIRTUAL MethodHandle.invokeBasic  (-- r)
    +     *                      GOTO DONE
    +     * CATCH:               (-- t)
    +     *                      DUP                                     (-- t t)
    +     * FINALLY_EXCEPTIONAL: (-- t t)
    +     *                      load cleanup                            (-- cleanup t t)
    +     *                      SWAP                                    (-- t cleanup t)
    +     *                      load default for r                      (-- r t cleanup t)
    +     *                      load args                               (-- args... r t cleanup t)
    +     *                      INVOKEVIRTUAL MethodHandle.invokeBasic  (-- r t)
    +     *                      POP                                     (-- t)
    +     *                      ATHROW
    +     * DONE:                (-- r)
    +     * }
    + */ + private Name emitTryFinally(int pos) { + Name args = lambdaForm.names[pos]; + Name invoker = lambdaForm.names[pos+1]; + Name result = lambdaForm.names[pos+2]; + + Label lFrom = new Label(); + Label lTo = new Label(); + Label lCatch = new Label(); + Label lDone = new Label(); + + Class returnType = result.function.resolvedHandle().type().returnType(); + boolean isNonVoid = returnType != void.class; + MethodType type = args.function.resolvedHandle().type() + .dropParameterTypes(0,1) + .changeReturnType(returnType); + MethodType cleanupType = type.insertParameterTypes(0, Throwable.class); + if (isNonVoid) { + cleanupType = cleanupType.insertParameterTypes(1, returnType); + } + String cleanupDesc = cleanupType.basicType().toMethodDescriptorString(); + + // exception handler table + mv.visitTryCatchBlock(lFrom, lTo, lCatch, "java/lang/Throwable"); + + // TRY: + mv.visitLabel(lFrom); + emitPushArgument(invoker, 0); // load target + emitPushArguments(args, 1); // load args (skip 0: method handle) + mv.visitMethodInsn(Opcodes.INVOKEVIRTUAL, MH, "invokeBasic", type.basicType().toMethodDescriptorString(), false); + mv.visitLabel(lTo); + + // FINALLY_NORMAL: + emitPushArgument(invoker, 1); // load cleanup + if (isNonVoid) { + mv.visitInsn(Opcodes.SWAP); + } + mv.visitInsn(Opcodes.ACONST_NULL); + if (isNonVoid) { + mv.visitInsn(Opcodes.SWAP); + } + emitPushArguments(args, 1); // load args (skip 0: method handle) + mv.visitMethodInsn(Opcodes.INVOKEVIRTUAL, MH, "invokeBasic", cleanupDesc, false); + mv.visitJumpInsn(Opcodes.GOTO, lDone); + + // CATCH: + mv.visitLabel(lCatch); + mv.visitInsn(Opcodes.DUP); + + // FINALLY_EXCEPTIONAL: + emitPushArgument(invoker, 1); // load cleanup + mv.visitInsn(Opcodes.SWAP); + if (isNonVoid) { + emitZero(BasicType.basicType(returnType)); // load default for result + } + emitPushArguments(args, 1); // load args (skip 0: method handle) + mv.visitMethodInsn(Opcodes.INVOKEVIRTUAL, MH, "invokeBasic", cleanupDesc, false); + if (isNonVoid) { + mv.visitInsn(Opcodes.POP); + } + mv.visitInsn(Opcodes.ATHROW); + + // DONE: + mv.visitLabel(lDone); + + return result; + } + + /** + * Emit bytecode for the loop idiom. + *

    + * The pattern looks like (Cf. MethodHandleImpl.loop): + *

    {@code
    +     * // a0: BMH
    +     * // a1: inits, a2: steps, a3: preds, a4: finis
    +     * // a5: box, a6: unbox
    +     * // a7 (and following): arguments
    +     * loop=Lambda(a0:L,a1:L,a2:L,a3:L,a4:L,a5:L,a6:L,a7:L)=>{
    +     *   t8:L=MethodHandle.invokeBasic(a5:L,a7:L);                  // box the arguments into an Object[]
    +     *   t9:L=MethodHandleImpl.loop(bt:L,a1:L,a2:L,a3:L,a4:L,t8:L); // call the loop executor (with supplied types in bt)
    +     *   t10:L=MethodHandle.invokeBasic(a6:L,t9:L);t10:L}           // unbox the result; return the result
    +     * }
    + *

    + * It is compiled into bytecode equivalent to the code seen in {@link MethodHandleImpl#loop(BasicType[], + * MethodHandle[], MethodHandle[], MethodHandle[], MethodHandle[], Object...)}, with the difference that no arrays + * will be used for local state storage. Instead, the local state will be mapped to actual stack slots. + *

    + * Bytecode generation applies an unrolling scheme to enable better bytecode generation regarding local state type + * handling. The generated bytecode will have the following form ({@code void} types are ignored for convenience). + * Assume there are {@code C} clauses in the loop. + *

    {@code
    +     * INIT: (INIT_SEQ for clause 1)
    +     *       ...
    +     *       (INIT_SEQ for clause C)
    +     * LOOP: (LOOP_SEQ for clause 1)
    +     *       ...
    +     *       (LOOP_SEQ for clause C)
    +     *       GOTO LOOP
    +     * DONE: ...
    +     * }
    + *

    + * The {@code INIT_SEQ_x} sequence for clause {@code x} (with {@code x} ranging from {@code 0} to {@code C-1}) has + * the following shape. Assume slot {@code vx} is used to hold the state for clause {@code x}. + *

    {@code
    +     * INIT_SEQ_x:  ALOAD inits
    +     *              CHECKCAST MethodHandle[]
    +     *              ICONST x
    +     *              AALOAD      // load the init handle for clause x
    +     *              load args
    +     *              INVOKEVIRTUAL MethodHandle.invokeBasic
    +     *              store vx
    +     * }
    + *

    + * The {@code LOOP_SEQ_x} sequence for clause {@code x} (with {@code x} ranging from {@code 0} to {@code C-1}) has + * the following shape. Again, assume slot {@code vx} is used to hold the state for clause {@code x}. + *

    {@code
    +     * LOOP_SEQ_x:  ALOAD steps
    +     *              CHECKCAST MethodHandle[]
    +     *              ICONST x
    +     *              AALOAD              // load the step handle for clause x
    +     *              load locals
    +     *              load args
    +     *              INVOKEVIRTUAL MethodHandle.invokeBasic
    +     *              store vx
    +     *              ALOAD preds
    +     *              CHECKCAST MethodHandle[]
    +     *              ICONST x
    +     *              AALOAD              // load the pred handle for clause x
    +     *              load locals
    +     *              load args
    +     *              INVOKEVIRTUAL MethodHandle.invokeBasic
    +     *              IFNE LOOP_SEQ_x+1   // predicate returned false -> jump to next clause
    +     *              ALOAD finis
    +     *              CHECKCAST MethodHandle[]
    +     *              ICONST x
    +     *              AALOAD              // load the fini handle for clause x
    +     *              load locals
    +     *              load args
    +     *              INVOKEVIRTUAL MethodHandle.invokeBasic
    +     *              GOTO DONE           // jump beyond end of clauses to return from loop
    +     * }
    + */ + private Name emitLoop(int pos) { + Name args = lambdaForm.names[pos]; + Name invoker = lambdaForm.names[pos+1]; + Name result = lambdaForm.names[pos+2]; + + // extract clause and loop-local state types + // find the type info in the loop invocation + BasicType[] loopClauseTypes = (BasicType[]) invoker.arguments[0]; + Class[] loopLocalStateTypes = Stream.of(loopClauseTypes). + filter(bt -> bt != BasicType.V_TYPE).map(BasicType::basicTypeClass).toArray(Class[]::new); + + final int firstLoopStateIndex = extendLocalsMap(loopLocalStateTypes); + + Class returnType = result.function.resolvedHandle().type().returnType(); + MethodType loopType = args.function.resolvedHandle().type() + .dropParameterTypes(0,1) + .changeReturnType(returnType); + MethodType loopHandleType = loopType.insertParameterTypes(0, loopLocalStateTypes); + MethodType predType = loopHandleType.changeReturnType(boolean.class); + MethodType finiType = loopHandleType; + + final int nClauses = loopClauseTypes.length; + + // indices to invoker arguments to load method handle arrays + final int inits = 1; + final int steps = 2; + final int preds = 3; + final int finis = 4; + + Label lLoop = new Label(); + Label lDone = new Label(); + Label lNext; + + // INIT: + for (int c = 0, state = 0; c < nClauses; ++c) { + MethodType cInitType = loopType.changeReturnType(loopClauseTypes[c].basicTypeClass()); + emitLoopHandleInvoke(invoker, inits, c, args, false, cInitType, loopLocalStateTypes, firstLoopStateIndex); + if (cInitType.returnType() != void.class) { + emitStoreInsn(BasicType.basicType(cInitType.returnType()), firstLoopStateIndex + state); + ++state; + } + } + + // LOOP: + mv.visitLabel(lLoop); + + for (int c = 0, state = 0; c < nClauses; ++c) { + lNext = new Label(); + + MethodType stepType = loopHandleType.changeReturnType(loopClauseTypes[c].basicTypeClass()); + boolean isVoid = stepType.returnType() == void.class; + + // invoke loop step + emitLoopHandleInvoke(invoker, steps, c, args, true, stepType, loopLocalStateTypes, firstLoopStateIndex); + if (!isVoid) { + emitStoreInsn(BasicType.basicType(stepType.returnType()), firstLoopStateIndex + state); + ++state; + } + + // invoke loop predicate + emitLoopHandleInvoke(invoker, preds, c, args, true, predType, loopLocalStateTypes, firstLoopStateIndex); + mv.visitJumpInsn(Opcodes.IFNE, lNext); + + // invoke fini + emitLoopHandleInvoke(invoker, finis, c, args, true, finiType, loopLocalStateTypes, firstLoopStateIndex); + mv.visitJumpInsn(Opcodes.GOTO, lDone); + + // this is the beginning of the next loop clause + mv.visitLabel(lNext); + } + + mv.visitJumpInsn(Opcodes.GOTO, lLoop); + + // DONE: + mv.visitLabel(lDone); + + return result; + } + + private int extendLocalsMap(Class[] types) { + int firstSlot = localsMap.length - 1; + localsMap = Arrays.copyOf(localsMap, localsMap.length + types.length); + localClasses = Arrays.copyOf(localClasses, localClasses.length + types.length); + System.arraycopy(types, 0, localClasses, firstSlot, types.length); + int index = localsMap[firstSlot - 1] + 1; + int lastSlots = 0; + for (int i = 0; i < types.length; ++i) { + localsMap[firstSlot + i] = index; + lastSlots = BasicType.basicType(localClasses[firstSlot + i]).basicTypeSlots(); + index += lastSlots; + } + localsMap[localsMap.length - 1] = index - lastSlots; + return firstSlot; + } + + private void emitLoopHandleInvoke(Name holder, int handles, int clause, Name args, boolean pushLocalState, + MethodType type, Class[] loopLocalStateTypes, int firstLoopStateSlot) { + // load handle for clause + emitPushArgument(holder, handles); + emitIconstInsn(clause); + mv.visitInsn(Opcodes.AALOAD); + // load loop state (preceding the other arguments) + if (pushLocalState) { + for (int s = 0; s < loopLocalStateTypes.length; ++s) { + emitLoadInsn(BasicType.basicType(loopLocalStateTypes[s]), firstLoopStateSlot + s); + } + } + // load loop args (skip 0: method handle) + emitPushArguments(args, 1); + mv.visitMethodInsn(Opcodes.INVOKEVIRTUAL, MH, "invokeBasic", type.toMethodDescriptorString(), false); + } + + private void emitZero(BasicType type) { + switch (type) { + case I_TYPE: mv.visitInsn(Opcodes.ICONST_0); break; + case J_TYPE: mv.visitInsn(Opcodes.LCONST_0); break; + case F_TYPE: mv.visitInsn(Opcodes.FCONST_0); break; + case D_TYPE: mv.visitInsn(Opcodes.DCONST_0); break; + case L_TYPE: mv.visitInsn(Opcodes.ACONST_NULL); break; + default: throw new InternalError("unknown type: " + type); + } + } + private void emitPushArguments(Name args) { emitPushArguments(args, 0); } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java index 45818bbf24a..745c38df2de 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,11 +33,9 @@ import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; -import java.lang.reflect.Field; import java.lang.reflect.Method; import java.util.Arrays; import java.util.HashMap; -import java.util.List; import static java.lang.invoke.LambdaForm.BasicType.*; import static java.lang.invoke.MethodHandleNatives.Constants.REF_invokeStatic; @@ -210,6 +208,29 @@ class LambdaForm { } return btypes; } + static String basicTypeDesc(BasicType[] types) { + if (types == null) { + return null; + } + if (types.length == 0) { + return ""; + } + StringBuilder sb = new StringBuilder(); + for (BasicType bt : types) { + sb.append(bt.basicTypeChar()); + } + return sb.toString(); + } + static int[] basicTypeOrds(BasicType[] types) { + if (types == null) { + return null; + } + int[] a = new int[types.length]; + for(int i = 0; i < types.length; ++i) { + a[i] = types[i].ordinal(); + } + return a; + } static char basicTypeChar(Class type) { return basicType(type).btChar; @@ -565,6 +586,69 @@ class LambdaForm { return MethodType.methodType(rtype, ptypes); } + /** + * Check if i-th name is a call to MethodHandleImpl.selectAlternative. + */ + boolean isSelectAlternative(int pos) { + // selectAlternative idiom: + // t_{n}:L=MethodHandleImpl.selectAlternative(...) + // t_{n+1}:?=MethodHandle.invokeBasic(t_{n}, ...) + if (pos+1 >= names.length) return false; + Name name0 = names[pos]; + Name name1 = names[pos+1]; + return name0.refersTo(MethodHandleImpl.class, "selectAlternative") && + name1.isInvokeBasic() && + name1.lastUseIndex(name0) == 0 && // t_{n+1}:?=MethodHandle.invokeBasic(t_{n}, ...) + lastUseIndex(name0) == pos+1; // t_{n} is local: used only in t_{n+1} + } + + private boolean isMatchingIdiom(int pos, String idiomName, int nArgs) { + if (pos+2 >= names.length) return false; + Name name0 = names[pos]; + Name name1 = names[pos+1]; + Name name2 = names[pos+2]; + return name1.refersTo(MethodHandleImpl.class, idiomName) && + name0.isInvokeBasic() && + name2.isInvokeBasic() && + name1.lastUseIndex(name0) == nArgs && // t_{n+1}:L=MethodHandleImpl.(, t_{n}); + lastUseIndex(name0) == pos+1 && // t_{n} is local: used only in t_{n+1} + name2.lastUseIndex(name1) == 1 && // t_{n+2}:?=MethodHandle.invokeBasic(*, t_{n+1}) + lastUseIndex(name1) == pos+2; // t_{n+1} is local: used only in t_{n+2} + } + + /** + * Check if i-th name is a start of GuardWithCatch idiom. + */ + boolean isGuardWithCatch(int pos) { + // GuardWithCatch idiom: + // t_{n}:L=MethodHandle.invokeBasic(...) + // t_{n+1}:L=MethodHandleImpl.guardWithCatch(*, *, *, t_{n}); + // t_{n+2}:?=MethodHandle.invokeBasic(*, t_{n+1}) + return isMatchingIdiom(pos, "guardWithCatch", 3); + } + + /** + * Check if i-th name is a start of the tryFinally idiom. + */ + boolean isTryFinally(int pos) { + // tryFinally idiom: + // t_{n}:L=MethodHandle.invokeBasic(...) + // t_{n+1}:L=MethodHandleImpl.tryFinally(*, *, t_{n}) + // t_{n+2}:?=MethodHandle.invokeBasic(*, t_{n+1}) + return isMatchingIdiom(pos, "tryFinally", 2); + } + + /** + * Check if i-th name is a start of the loop idiom. + */ + boolean isLoop(int pos) { + // loop idiom: + // t_{n}:L=MethodHandle.invokeBasic(...) + // t_{n+1}:L=MethodHandleImpl.loop(types, *, *, *, *, t_{n}) + // t_{n+2}:?=MethodHandle.invokeBasic(*, t_{n+1}) + return isMatchingIdiom(pos, "loop", 5); + } + /* * Code generation issues: * @@ -1421,6 +1505,39 @@ class LambdaForm { return !isParam() && arguments.length == 0 && function.isConstantZero(); } + boolean refersTo(Class declaringClass, String methodName) { + return function != null && + function.member() != null && function.member().refersTo(declaringClass, methodName); + } + + /** + * Check if MemberName is a call to MethodHandle.invokeBasic. + */ + boolean isInvokeBasic() { + if (function == null) + return false; + if (arguments.length < 1) + return false; // must have MH argument + MemberName member = function.member(); + return member != null && member.refersTo(MethodHandle.class, "invokeBasic") && + !member.isPublic() && !member.isStatic(); + } + + /** + * Check if MemberName is a call to MethodHandle.linkToStatic, etc. + */ + boolean isLinkerMethodInvoke() { + if (function == null) + return false; + if (arguments.length < 1) + return false; // must have MH argument + MemberName member = function.member(); + return member != null && + member.getDeclaringClass() == MethodHandle.class && + !member.isPublic() && member.isStatic() && + member.getName().startsWith("linkTo"); + } + public String toString() { return (isParam()?"a":"t")+(index >= 0 ? index : System.identityHashCode(this))+":"+typeChar(); } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormBuffer.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormBuffer.java index cdc88be3250..cc4b97b5479 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormBuffer.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormBuffer.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -249,7 +249,7 @@ final class LambdaFormBuffer { assert(inTrans()); } - private void changeName(int i, Name name) { + void changeName(int i, Name name) { assert(inTrans()); assert(i < length); Name oldName = names[i]; diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java index 8cf5811e78d..9d6c865eae5 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,15 +25,17 @@ package java.lang.invoke; +import sun.invoke.util.Wrapper; + import java.lang.ref.SoftReference; import java.util.Arrays; -import static java.lang.invoke.LambdaForm.*; -import static java.lang.invoke.LambdaForm.BasicType.*; -import static java.lang.invoke.MethodHandleImpl.Intrinsic; import java.util.Collections; import java.util.concurrent.ConcurrentHashMap; -import sun.invoke.util.Wrapper; +import static java.lang.invoke.LambdaForm.*; +import static java.lang.invoke.LambdaForm.BasicType.*; +import static java.lang.invoke.MethodHandleImpl.Intrinsic; +import static java.lang.invoke.MethodHandleImpl.NF_loop; /** Transforms on LFs. * A lambda-form editor can derive new LFs from its base LF. @@ -73,7 +75,8 @@ class LambdaFormEditor { FILTER_ARG, FILTER_RETURN, FILTER_RETURN_TO_ZERO, COLLECT_ARGS, COLLECT_ARGS_TO_VOID, COLLECT_ARGS_TO_ARRAY, FOLD_ARGS, FOLD_ARGS_TO_VOID, - PERMUTE_ARGS + PERMUTE_ARGS, + LOCAL_TYPES //maybe add more for guard with test, catch exception, pointwise type conversions } @@ -847,6 +850,32 @@ class LambdaFormEditor { return putInCache(key, form); } + LambdaForm noteLoopLocalTypesForm(int pos, BasicType[] localTypes) { + assert(lambdaForm.isLoop(pos)); + int[] desc = BasicType.basicTypeOrds(localTypes); + desc = Arrays.copyOf(desc, desc.length + 1); + desc[desc.length - 1] = pos; + Transform key = Transform.of(Transform.Kind.LOCAL_TYPES, desc); + LambdaForm form = getInCache(key); + if (form != null) { + return form; + } + + // replace the null entry in the MHImpl.loop invocation with localTypes + Name invokeLoop = lambdaForm.names[pos + 1]; + assert(invokeLoop.function == NF_loop); + Object[] args = Arrays.copyOf(invokeLoop.arguments, invokeLoop.arguments.length); + assert(args[0] == null); + args[0] = localTypes; + + LambdaFormBuffer buf = buffer(); + buf.startEdit(); + buf.changeName(pos + 1, new Name(NF_loop, args)); + form = buf.endEdit(); + + return putInCache(key, form); + } + static boolean permutedTypesMatch(int[] reorder, BasicType[] types, Name[] names, int skip) { for (int i = 0; i < reorder.length; i++) { assert (names[skip + i].isParam()); diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MemberName.java b/jdk/src/java.base/share/classes/java/lang/invoke/MemberName.java index c720ca82a8a..776d5266db3 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MemberName.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MemberName.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -32,8 +32,8 @@ import sun.invoke.util.VerifyAccess; import java.lang.reflect.Constructor; import java.lang.reflect.Field; -import java.lang.reflect.Method; import java.lang.reflect.Member; +import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.lang.reflect.Module; import java.util.ArrayList; @@ -41,10 +41,12 @@ import java.util.Arrays; import java.util.Collections; import java.util.Iterator; import java.util.List; -import static java.lang.invoke.MethodHandleNatives.Constants.*; -import static java.lang.invoke.MethodHandleStatics.*; import java.util.Objects; +import static java.lang.invoke.MethodHandleNatives.Constants.*; +import static java.lang.invoke.MethodHandleStatics.newIllegalArgumentException; +import static java.lang.invoke.MethodHandleStatics.newInternalError; + /** * A {@code MemberName} is a compact symbolic datum which fully characterizes * a method or field reference. @@ -500,6 +502,13 @@ import java.util.Objects; lookupClass, mode); } + /** + * Check if MemberName is a call to a method named {@code name} in class {@code declaredClass}. + */ + public boolean refersTo(Class declc, String n) { + return clazz == declc && getName().equals(n); + } + /** Initialize a query. It is not resolved. */ private void init(Class defClass, String name, Object type, int flags) { // defining class is allowed to be null (for a naked name/type pair) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java index ac0b5847fff..adaca60874f 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java @@ -25,15 +25,9 @@ package java.lang.invoke; -import java.lang.reflect.Array; -import java.security.AccessController; -import java.security.PrivilegedAction; -import java.util.Arrays; -import java.util.Collections; -import java.util.Iterator; -import java.util.List; -import java.util.function.Function; - +import jdk.internal.org.objectweb.asm.AnnotationVisitor; +import jdk.internal.org.objectweb.asm.ClassWriter; +import jdk.internal.org.objectweb.asm.MethodVisitor; import jdk.internal.reflect.CallerSensitive; import jdk.internal.reflect.Reflection; import jdk.internal.vm.annotation.Stable; @@ -42,9 +36,16 @@ import sun.invoke.util.ValueConversions; import sun.invoke.util.VerifyType; import sun.invoke.util.Wrapper; -import jdk.internal.org.objectweb.asm.AnnotationVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.MethodVisitor; +import java.lang.reflect.Array; +import java.security.AccessController; +import java.security.PrivilegedAction; +import java.util.Arrays; +import java.util.Collections; +import java.util.Iterator; +import java.util.List; +import java.util.function.Function; +import java.util.stream.Collectors; +import java.util.stream.Stream; import static java.lang.invoke.LambdaForm.*; import static java.lang.invoke.MethodHandleStatics.*; @@ -1046,26 +1047,13 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; // Box arguments and wrap them into Object[]: ValueConversions.array(). MethodType varargsType = type.changeReturnType(Object[].class); MethodHandle collectArgs = varargsArray(type.parameterCount()).asType(varargsType); - // Result unboxing: ValueConversions.unbox() OR ValueConversions.identity() OR ValueConversions.ignore(). - MethodHandle unboxResult; - Class rtype = type.returnType(); - if (rtype.isPrimitive()) { - if (rtype == void.class) { - unboxResult = ValueConversions.ignore(); - } else { - Wrapper w = Wrapper.forPrimitiveType(type.returnType()); - unboxResult = ValueConversions.unboxExact(w); - } - } else { - unboxResult = MethodHandles.identity(Object.class); - } + MethodHandle unboxResult = unboxResultHandle(type.returnType()); BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLLLL(); BoundMethodHandle mh; try { - mh = (BoundMethodHandle) - data.constructor().invokeBasic(type, form, (Object) target, (Object) exType, (Object) catcher, - (Object) collectArgs, (Object) unboxResult); + mh = (BoundMethodHandle) data.constructor().invokeBasic(type, form, (Object) target, (Object) exType, + (Object) catcher, (Object) collectArgs, (Object) unboxResult); } catch (Throwable ex) { throw uncaughtException(ex); } @@ -1085,16 +1073,18 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; return target.asFixedArity().invokeWithArguments(av); } catch (Throwable t) { if (!exType.isInstance(t)) throw t; - return catcher.asFixedArity().invokeWithArguments(prepend(t, av)); + return catcher.asFixedArity().invokeWithArguments(prepend(av, t)); } } - /** Prepend an element {@code elem} to an {@code array}. */ + /** Prepend elements to an array. */ @LambdaForm.Hidden - private static Object[] prepend(Object elem, Object[] array) { - Object[] newArray = new Object[array.length+1]; - newArray[0] = elem; - System.arraycopy(array, 0, newArray, 1, array.length); + private static Object[] prepend(Object[] array, Object... elems) { + int nArray = array.length; + int nElems = elems.length; + Object[] newArray = new Object[nArray + nElems]; + System.arraycopy(elems, 0, newArray, 0, nElems); + System.arraycopy(array, 0, newArray, nElems, nArray); return newArray; } @@ -1352,6 +1342,8 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; enum Intrinsic { SELECT_ALTERNATIVE, GUARD_WITH_CATCH, + TRY_FINALLY, + LOOP, NEW_ARRAY, ARRAY_LOAD, ARRAY_STORE, @@ -1363,7 +1355,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; /** Mark arbitrary method handle as intrinsic. * InvokerBytecodeGenerator uses this info to produce more efficient bytecode shape. */ - private static final class IntrinsicMethodHandle extends DelegatingMethodHandle { + static final class IntrinsicMethodHandle extends DelegatingMethodHandle { private final MethodHandle target; private final Intrinsic intrinsicName; @@ -1694,6 +1686,8 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; NF_checkSpreadArgument, NF_guardWithCatch, NF_throwException, + NF_tryFinally, + NF_loop, NF_profileBoolean; static { @@ -1703,6 +1697,11 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; NF_guardWithCatch = new NamedFunction(MethodHandleImpl.class .getDeclaredMethod("guardWithCatch", MethodHandle.class, Class.class, MethodHandle.class, Object[].class)); + NF_tryFinally = new NamedFunction(MethodHandleImpl.class + .getDeclaredMethod("tryFinally", MethodHandle.class, MethodHandle.class, Object[].class)); + NF_loop = new NamedFunction(MethodHandleImpl.class + .getDeclaredMethod("loop", BasicType[].class, MethodHandle[].class, MethodHandle[].class, + MethodHandle[].class, MethodHandle[].class, Object[].class)); NF_throwException = new NamedFunction(MethodHandleImpl.class .getDeclaredMethod("throwException", Throwable.class)); NF_profileBoolean = new NamedFunction(MethodHandleImpl.class @@ -1712,14 +1711,25 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; } } + /** Result unboxing: ValueConversions.unbox() OR ValueConversions.identity() OR ValueConversions.ignore(). */ + private static MethodHandle unboxResultHandle(Class returnType) { + if (returnType.isPrimitive()) { + if (returnType == void.class) { + return ValueConversions.ignore(); + } else { + Wrapper w = Wrapper.forPrimitiveType(returnType); + return ValueConversions.unboxExact(w); + } + } else { + return MethodHandles.identity(Object.class); + } + } + /** - * Assembles a loop method handle from the given handles and type information. This works by binding and configuring - * the {@linkplain #looper(MethodHandle[], MethodHandle[], MethodHandle[], MethodHandle[], int, int, Object[]) "most - * generic loop"}. + * Assembles a loop method handle from the given handles and type information. * * @param tloop the return type of the loop. * @param targs types of the arguments to be passed to the loop. - * @param tvars types of loop-local variables. * @param init sanitized array of initializers for loop-local variables. * @param step sanitited array of loop bodies. * @param pred sanitized array of predicates. @@ -1727,64 +1737,144 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; * * @return a handle that, when invoked, will execute the loop. */ - static MethodHandle makeLoop(Class tloop, List> targs, List> tvars, List init, - List step, List pred, List fini) { - MethodHandle[] ainit = toArrayArgs(init); - MethodHandle[] astep = toArrayArgs(step); - MethodHandle[] apred = toArrayArgs(pred); - MethodHandle[] afini = toArrayArgs(fini); + static MethodHandle makeLoop(Class tloop, List> targs, List init, List step, + List pred, List fini) { + MethodType type = MethodType.methodType(tloop, targs); + BasicType[] initClauseTypes = + init.stream().map(h -> h.type().returnType()).map(BasicType::basicType).toArray(BasicType[]::new); + LambdaForm form = makeLoopForm(type.basicType(), initClauseTypes); - MethodHandle l = getConstantHandle(MH_looper); + // Prepare auxiliary method handles used during LambdaForm interpretation. + // Box arguments and wrap them into Object[]: ValueConversions.array(). + MethodType varargsType = type.changeReturnType(Object[].class); + MethodHandle collectArgs = varargsArray(type.parameterCount()).asType(varargsType); + MethodHandle unboxResult = unboxResultHandle(tloop); - // Bind the statically known arguments. - l = MethodHandles.insertArguments(l, 0, ainit, astep, apred, afini, tvars.size(), targs.size()); + BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLLLLL(); + BoundMethodHandle mh; + try { + mh = (BoundMethodHandle) data.constructor().invokeBasic(type, form, (Object) toArray(init), + (Object) toArray(step), (Object) toArray(pred), (Object) toArray(fini), (Object) collectArgs, + (Object) unboxResult); + } catch (Throwable ex) { + throw uncaughtException(ex); + } + assert(mh.type() == type); + return mh; + } - // Turn the args array into an argument list. - l = l.asCollector(Object[].class, targs.size()); - - // Finally, make loop type. - MethodType loopType = MethodType.methodType(tloop, targs); - l = l.asType(loopType); - - return l; + private static MethodHandle[] toArray(List l) { + return l.toArray(new MethodHandle[0]); } /** - * Converts all handles in the {@code hs} array to handles that accept an array of arguments. - * - * @param hs method handles to be converted. - * - * @return the {@code hs} array, with all method handles therein converted. + * Loops introduce some complexity as they can have additional local state. Hence, LambdaForms for loops are + * generated from a template. The LambdaForm template shape for the loop combinator is as follows (assuming one + * reference parameter passed in {@code a1}, and a reference return type, with the return value represented by + * {@code t12}): + *
    {@code
    +     *  loop=Lambda(a0:L,a1:L)=>{
    +     *    t2:L=BoundMethodHandle$Species_L6.argL0(a0:L);             // array of init method handles
    +     *    t3:L=BoundMethodHandle$Species_L6.argL1(a0:L);             // array of step method handles
    +     *    t4:L=BoundMethodHandle$Species_L6.argL2(a0:L);             // array of pred method handles
    +     *    t5:L=BoundMethodHandle$Species_L6.argL3(a0:L);             // array of fini method handles
    +     *    t6:L=BoundMethodHandle$Species_L6.argL4(a0:L);             // helper handle to box the arguments into an Object[]
    +     *    t7:L=BoundMethodHandle$Species_L6.argL5(a0:L);             // helper handle to unbox the result
    +     *    t8:L=MethodHandle.invokeBasic(t6:L,a1:L);                  // box the arguments into an Object[]
    +     *    t9:L=MethodHandleImpl.loop(null,t2:L,t3:L,t4:L,t5:L,t6:L); // call the loop executor
    +     *    t10:L=MethodHandle.invokeBasic(t7:L,t9:L);t10:L}           // unbox the result; return the result
    +     * }
    + *

    + * {@code argL0} through {@code argL3} are the arrays of init, step, pred, and fini method handles. + * {@code argL4} and {@code argL5} are auxiliary method handles: {@code argL2} boxes arguments and wraps them into + * {@code Object[]} ({@code ValueConversions.array()}), and {@code argL3} unboxes the result if necessary + * ({@code ValueConversions.unbox()}). + *

    + * Having {@code t6} and {@code t7} passed in via a BMH and not hardcoded in the lambda form allows to share lambda + * forms among loop combinators with the same basic type. + *

    + * The above template is instantiated by using the {@link LambdaFormEditor} to replace the {@code null} argument to + * the {@code loop} invocation with the {@code BasicType} array describing the loop clause types. This argument is + * ignored in the loop invoker, but will be extracted and used in {@linkplain InvokerBytecodeGenerator#emitLoop(int) + * bytecode generation}. */ - static MethodHandle[] toArrayArgs(List hs) { - return hs.stream().map(h -> h.asSpreader(Object[].class, h.type().parameterCount())).toArray(MethodHandle[]::new); + private static LambdaForm makeLoopForm(MethodType basicType, BasicType[] localVarTypes) { + MethodType lambdaType = basicType.invokerType(); + + final int THIS_MH = 0; // the BMH_LLLLLL + final int ARG_BASE = 1; // start of incoming arguments + final int ARG_LIMIT = ARG_BASE + basicType.parameterCount(); + + int nameCursor = ARG_LIMIT; + final int GET_INITS = nameCursor++; + final int GET_STEPS = nameCursor++; + final int GET_PREDS = nameCursor++; + final int GET_FINIS = nameCursor++; + final int GET_COLLECT_ARGS = nameCursor++; + final int GET_UNBOX_RESULT = nameCursor++; + final int BOXED_ARGS = nameCursor++; + final int LOOP = nameCursor++; + final int UNBOX_RESULT = nameCursor++; + + LambdaForm lform = basicType.form().cachedLambdaForm(MethodTypeForm.LF_LOOP); + if (lform == null) { + Name[] names = arguments(nameCursor - ARG_LIMIT, lambdaType); + + BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLLLLL(); + names[THIS_MH] = names[THIS_MH].withConstraint(data); + names[GET_INITS] = new Name(data.getterFunction(0), names[THIS_MH]); + names[GET_STEPS] = new Name(data.getterFunction(1), names[THIS_MH]); + names[GET_PREDS] = new Name(data.getterFunction(2), names[THIS_MH]); + names[GET_FINIS] = new Name(data.getterFunction(3), names[THIS_MH]); + names[GET_COLLECT_ARGS] = new Name(data.getterFunction(4), names[THIS_MH]); + names[GET_UNBOX_RESULT] = new Name(data.getterFunction(5), names[THIS_MH]); + + // t_{i}:L=MethodHandle.invokeBasic(collectArgs:L,a1:L,...); + MethodType collectArgsType = basicType.changeReturnType(Object.class); + MethodHandle invokeBasic = MethodHandles.basicInvoker(collectArgsType); + Object[] args = new Object[invokeBasic.type().parameterCount()]; + args[0] = names[GET_COLLECT_ARGS]; + System.arraycopy(names, ARG_BASE, args, 1, ARG_LIMIT - ARG_BASE); + names[BOXED_ARGS] = new Name(makeIntrinsic(invokeBasic, Intrinsic.LOOP), args); + + // t_{i+1}:L=MethodHandleImpl.loop(localTypes:L,inits:L,steps:L,preds:L,finis:L,t_{i}:L); + Object[] lArgs = + new Object[]{null, // placeholder for BasicType[] localTypes - will be added by LambdaFormEditor + names[GET_INITS], names[GET_STEPS], names[GET_PREDS], names[GET_FINIS], names[BOXED_ARGS]}; + names[LOOP] = new Name(NF_loop, lArgs); + + // t_{i+2}:I=MethodHandle.invokeBasic(unbox:L,t_{i+1}:L); + MethodHandle invokeBasicUnbox = MethodHandles.basicInvoker(MethodType.methodType(basicType.rtype(), Object.class)); + Object[] unboxArgs = new Object[]{names[GET_UNBOX_RESULT], names[LOOP]}; + names[UNBOX_RESULT] = new Name(invokeBasicUnbox, unboxArgs); + + lform = basicType.form().setCachedLambdaForm(MethodTypeForm.LF_LOOP, + new LambdaForm("loop", lambdaType.parameterCount(), names)); + } + + // BOXED_ARGS is the index into the names array where the loop idiom starts + return lform.editor().noteLoopLocalTypesForm(BOXED_ARGS, localVarTypes); } + /** - * This method embodies the most generic loop for use by {@link MethodHandles#loop(MethodHandle[][])}. A handle on - * it will be transformed into a handle on a concrete loop instantiation by {@link #makeLoop}. - * - * @param init loop-local variable initializers. - * @param step bodies. - * @param pred predicates. - * @param fini finalizers. - * @param varSize number of loop-local variables. - * @param nArgs number of arguments passed to the loop. - * @param args arguments to the loop invocation. - * - * @return the result of executing the loop. + * Intrinsified during LambdaForm compilation + * (see {@link InvokerBytecodeGenerator#emitLoop(int)}). */ - static Object looper(MethodHandle[] init, MethodHandle[] step, MethodHandle[] pred, MethodHandle[] fini, - int varSize, int nArgs, Object[] args) throws Throwable { + @LambdaForm.Hidden + static Object loop(BasicType[] localTypes, MethodHandle[] init, MethodHandle[] step, MethodHandle[] pred, + MethodHandle[] fini, Object... av) throws Throwable { + int varSize = (int) Stream.of(init).filter(h -> h.type().returnType() != void.class).count(); + int nArgs = init[0].type().parameterCount(); Object[] varsAndArgs = new Object[varSize + nArgs]; for (int i = 0, v = 0; i < init.length; ++i) { if (init[i].type().returnType() == void.class) { - init[i].invoke(args); + init[i].asFixedArity().invokeWithArguments(av); } else { - varsAndArgs[v++] = init[i].invoke(args); + varsAndArgs[v++] = init[i].asFixedArity().invokeWithArguments(av); } } - System.arraycopy(args, 0, varsAndArgs, varSize, nArgs); + System.arraycopy(av, 0, varsAndArgs, varSize, nArgs); final int nSteps = step.length; for (; ; ) { for (int i = 0, v = 0; i < nSteps; ++i) { @@ -1792,12 +1882,12 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; MethodHandle s = step[i]; MethodHandle f = fini[i]; if (s.type().returnType() == void.class) { - s.invoke(varsAndArgs); + s.asFixedArity().invokeWithArguments(varsAndArgs); } else { - varsAndArgs[v++] = s.invoke(varsAndArgs); + varsAndArgs[v++] = s.asFixedArity().invokeWithArguments(varsAndArgs); } - if (!(boolean) p.invoke(varsAndArgs)) { - return f.invoke(varsAndArgs); + if (!(boolean) p.asFixedArity().invokeWithArguments(varsAndArgs)) { + return f.asFixedArity().invokeWithArguments(varsAndArgs); } } } @@ -1879,77 +1969,127 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; * * @param target the target to execute in a {@code try-finally} block. * @param cleanup the cleanup to execute in the {@code finally} block. - * @param type the result type of the entire construct. + * @param rtype the result type of the entire construct. * @param argTypes the types of the arguments. * * @return a handle on the constructed {@code try-finally} block. */ - static MethodHandle makeTryFinally(MethodHandle target, MethodHandle cleanup, Class type, List> argTypes) { - MethodHandle tf = getConstantHandle(type == void.class ? MH_tryFinallyVoidExec : MH_tryFinallyExec); + static MethodHandle makeTryFinally(MethodHandle target, MethodHandle cleanup, Class rtype, List> argTypes) { + MethodType type = MethodType.methodType(rtype, argTypes); + LambdaForm form = makeTryFinallyForm(type.basicType()); - // Bind the statically known arguments. - tf = MethodHandles.insertArguments(tf, 0, target, cleanup); + // Prepare auxiliary method handles used during LambdaForm interpretation. + // Box arguments and wrap them into Object[]: ValueConversions.array(). + MethodType varargsType = type.changeReturnType(Object[].class); + MethodHandle collectArgs = varargsArray(type.parameterCount()).asType(varargsType); + MethodHandle unboxResult = unboxResultHandle(rtype); - // Turn the args array into an argument list. - tf = tf.asCollector(Object[].class, argTypes.size()); - - // Finally, make try-finally type. - MethodType tfType = MethodType.methodType(type, argTypes); - tf = tf.asType(tfType); - - return tf; + BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLLL(); + BoundMethodHandle mh; + try { + mh = (BoundMethodHandle) data.constructor().invokeBasic(type, form, (Object) target, (Object) cleanup, + (Object) collectArgs, (Object) unboxResult); + } catch (Throwable ex) { + throw uncaughtException(ex); + } + assert(mh.type() == type); + return mh; } /** - * A method that will be bound during construction of a {@code try-finally} handle with non-{@code void} return type - * by {@link MethodHandles#tryFinally(MethodHandle, MethodHandle)}. - * - * @param target the handle to wrap in a {@code try-finally} block. This will be bound. - * @param cleanup the handle to run in any case before returning. This will be bound. - * @param args the arguments to the call. These will remain as the argument list. - * - * @return whatever the execution of the {@code target} returned (it may have been modified by the execution of - * {@code cleanup}). - * @throws Throwable in case anything is thrown by the execution of {@code target}, the {@link Throwable} will be - * passed to the {@code cleanup} handle, which may decide to throw any exception it sees fit. + * The LambdaForm shape for the tryFinally combinator is as follows (assuming one reference parameter passed in + * {@code a1}, and a reference return type, with the return value represented by {@code t8}): + *

    {@code
    +     *  tryFinally=Lambda(a0:L,a1:L)=>{
    +     *    t2:L=BoundMethodHandle$Species_LLLL.argL0(a0:L);  // target method handle
    +     *    t3:L=BoundMethodHandle$Species_LLLL.argL1(a0:L);  // cleanup method handle
    +     *    t4:L=BoundMethodHandle$Species_LLLL.argL2(a0:L);  // helper handle to box the arguments into an Object[]
    +     *    t5:L=BoundMethodHandle$Species_LLLL.argL3(a0:L);  // helper handle to unbox the result
    +     *    t6:L=MethodHandle.invokeBasic(t4:L,a1:L);         // box the arguments into an Object[]
    +     *    t7:L=MethodHandleImpl.tryFinally(t2:L,t3:L,t6:L); // call the tryFinally executor
    +     *    t8:L=MethodHandle.invokeBasic(t5:L,t7:L);t8:L}    // unbox the result; return the result
    +     * }
    + *

    + * {@code argL0} and {@code argL1} are the target and cleanup method handles. + * {@code argL2} and {@code argL3} are auxiliary method handles: {@code argL2} boxes arguments and wraps them into + * {@code Object[]} ({@code ValueConversions.array()}), and {@code argL3} unboxes the result if necessary + * ({@code ValueConversions.unbox()}). + *

    + * Having {@code t4} and {@code t5} passed in via a BMH and not hardcoded in the lambda form allows to share lambda + * forms among tryFinally combinators with the same basic type. */ - static Object tryFinallyExecutor(MethodHandle target, MethodHandle cleanup, Object[] args) throws Throwable { + private static LambdaForm makeTryFinallyForm(MethodType basicType) { + MethodType lambdaType = basicType.invokerType(); + + LambdaForm lform = basicType.form().cachedLambdaForm(MethodTypeForm.LF_TF); + if (lform != null) { + return lform; + } + final int THIS_MH = 0; // the BMH_LLLL + final int ARG_BASE = 1; // start of incoming arguments + final int ARG_LIMIT = ARG_BASE + basicType.parameterCount(); + + int nameCursor = ARG_LIMIT; + final int GET_TARGET = nameCursor++; + final int GET_CLEANUP = nameCursor++; + final int GET_COLLECT_ARGS = nameCursor++; + final int GET_UNBOX_RESULT = nameCursor++; + final int BOXED_ARGS = nameCursor++; + final int TRY_FINALLY = nameCursor++; + final int UNBOX_RESULT = nameCursor++; + + Name[] names = arguments(nameCursor - ARG_LIMIT, lambdaType); + + BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLLL(); + names[THIS_MH] = names[THIS_MH].withConstraint(data); + names[GET_TARGET] = new Name(data.getterFunction(0), names[THIS_MH]); + names[GET_CLEANUP] = new Name(data.getterFunction(1), names[THIS_MH]); + names[GET_COLLECT_ARGS] = new Name(data.getterFunction(2), names[THIS_MH]); + names[GET_UNBOX_RESULT] = new Name(data.getterFunction(3), names[THIS_MH]); + + // t_{i}:L=MethodHandle.invokeBasic(collectArgs:L,a1:L,...); + MethodType collectArgsType = basicType.changeReturnType(Object.class); + MethodHandle invokeBasic = MethodHandles.basicInvoker(collectArgsType); + Object[] args = new Object[invokeBasic.type().parameterCount()]; + args[0] = names[GET_COLLECT_ARGS]; + System.arraycopy(names, ARG_BASE, args, 1, ARG_LIMIT-ARG_BASE); + names[BOXED_ARGS] = new Name(makeIntrinsic(invokeBasic, Intrinsic.TRY_FINALLY), args); + + // t_{i+1}:L=MethodHandleImpl.tryFinally(target:L,exType:L,catcher:L,t_{i}:L); + Object[] tfArgs = new Object[] {names[GET_TARGET], names[GET_CLEANUP], names[BOXED_ARGS]}; + names[TRY_FINALLY] = new Name(NF_tryFinally, tfArgs); + + // t_{i+2}:I=MethodHandle.invokeBasic(unbox:L,t_{i+1}:L); + MethodHandle invokeBasicUnbox = MethodHandles.basicInvoker(MethodType.methodType(basicType.rtype(), Object.class)); + Object[] unboxArgs = new Object[] {names[GET_UNBOX_RESULT], names[TRY_FINALLY]}; + names[UNBOX_RESULT] = new Name(invokeBasicUnbox, unboxArgs); + + lform = new LambdaForm("tryFinally", lambdaType.parameterCount(), names); + + return basicType.form().setCachedLambdaForm(MethodTypeForm.LF_TF, lform); + } + + /** + * Intrinsified during LambdaForm compilation + * (see {@link InvokerBytecodeGenerator#emitTryFinally emitTryFinally}). + */ + @LambdaForm.Hidden + static Object tryFinally(MethodHandle target, MethodHandle cleanup, Object... av) throws Throwable { Throwable t = null; Object r = null; try { - r = target.invoke(args); + // Use asFixedArity() to avoid unnecessary boxing of last argument for VarargsCollector case. + r = target.asFixedArity().invokeWithArguments(av); } catch (Throwable thrown) { t = thrown; throw t; } finally { - r = cleanup.invoke(t, r, args); + Object[] args = target.type().returnType() == void.class ? prepend(av, t) : prepend(av, t, r); + r = cleanup.asFixedArity().invokeWithArguments(args); } return r; } - /** - * A method that will be bound during construction of a {@code try-finally} handle with {@code void} return type by - * {@link MethodHandles#tryFinally(MethodHandle, MethodHandle)}. - * - * @param target the handle to wrap in a {@code try-finally} block. This will be bound. - * @param cleanup the handle to run in any case before returning. This will be bound. - * @param args the arguments to the call. These will remain as the argument list. - * - * @throws Throwable in case anything is thrown by the execution of {@code target}, the {@link Throwable} will be - * passed to the {@code cleanup} handle, which may decide to throw any exception it sees fit. - */ - static void tryFinallyVoidExecutor(MethodHandle target, MethodHandle cleanup, Object[] args) throws Throwable { - Throwable t = null; - try { - target.invoke(args); - } catch (Throwable thrown) { - t = thrown; - throw t; - } finally { - cleanup.invoke(t, args); - } - } - // Indexes into constant method handles: static final int MH_cast = 0, @@ -1958,17 +2098,14 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; MH_fillNewTypedArray = 3, MH_fillNewArray = 4, MH_arrayIdentity = 5, - MH_looper = 6, - MH_countedLoopPred = 7, - MH_countedLoopStep = 8, - MH_iteratePred = 9, - MH_initIterator = 10, - MH_iterateNext = 11, - MH_tryFinallyExec = 12, - MH_tryFinallyVoidExec = 13, - MH_decrementCounter = 14, - MH_Array_newInstance = 15, - MH_LIMIT = 16; + MH_countedLoopPred = 6, + MH_countedLoopStep = 7, + MH_iteratePred = 8, + MH_initIterator = 9, + MH_iterateNext = 10, + MH_decrementCounter = 11, + MH_Array_newInstance = 12, + MH_LIMIT = 13; static MethodHandle getConstantHandle(int idx) { MethodHandle handle = HANDLES[idx]; @@ -2013,10 +2150,6 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; return makeIntrinsic(IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "selectAlternative", MethodType.methodType(MethodHandle.class, boolean.class, MethodHandle.class, MethodHandle.class)), Intrinsic.SELECT_ALTERNATIVE); - case MH_looper: - return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "looper", MethodType.methodType(Object.class, - MethodHandle[].class, MethodHandle[].class, MethodHandle[].class, MethodHandle[].class, - int.class, int.class, Object[].class)); case MH_countedLoopPred: return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "countedLoopPredicate", MethodType.methodType(boolean.class, int.class, int.class)); @@ -2032,12 +2165,6 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; case MH_iterateNext: return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "iterateNext", MethodType.methodType(Object.class, Iterator.class)); - case MH_tryFinallyExec: - return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "tryFinallyExecutor", - MethodType.methodType(Object.class, MethodHandle.class, MethodHandle.class, Object[].class)); - case MH_tryFinallyVoidExec: - return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "tryFinallyVoidExecutor", - MethodType.methodType(void.class, MethodHandle.class, MethodHandle.class, Object[].class)); case MH_decrementCounter: return IMPL_LOOKUP.findStatic(MethodHandleImpl.class, "decrementCounter", MethodType.methodType(int.class, int.class)); diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java index a525b1b9518..8b31f502c27 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java @@ -4233,7 +4233,7 @@ assertEquals("boojum", (String) catTrace.invokeExact("boo", "jum")); assert Stream.of(fstep, fpred, ffini).flatMap(List::stream).map(MethodHandle::type).map(MethodType::parameterList). allMatch(pl -> pl.equals(commonParameterSequence)); - return MethodHandleImpl.makeLoop(loopReturnType, commonSuffix, commonPrefix, finit, fstep, fpred, ffini); + return MethodHandleImpl.makeLoop(loopReturnType, commonSuffix, finit, fstep, fpred, ffini); } private static List fillParameterTypes(List hs, final List> targetParams) { @@ -4740,10 +4740,8 @@ assertEquals("boojum", (String) catTrace.invokeExact("boo", "jum")); // The cleanup parameter list (minus the leading Throwable and result parameters) must be a sublist of the // target parameter list. cleanup = dropArgumentsToMatch(cleanup, (rtype == void.class ? 1 : 2), targetParamTypes, 0); - MethodHandle aTarget = target.asSpreader(Object[].class, target.type().parameterCount()); - MethodHandle aCleanup = cleanup.asSpreader(Object[].class, targetParamTypes.size()); - return MethodHandleImpl.makeTryFinally(aTarget, aCleanup, rtype, targetParamTypes); + return MethodHandleImpl.makeTryFinally(target, cleanup, rtype, targetParamTypes); } /** diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodTypeForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodTypeForm.java index e988252c8bc..c67ea418a6c 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodTypeForm.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodTypeForm.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,8 +27,10 @@ package java.lang.invoke; import jdk.internal.vm.annotation.Stable; import sun.invoke.util.Wrapper; + import java.lang.ref.SoftReference; -import static java.lang.invoke.MethodHandleStatics.*; + +import static java.lang.invoke.MethodHandleStatics.newIllegalArgumentException; /** * Shared information for a group of method types, which differ @@ -81,7 +83,9 @@ final class MethodTypeForm { LF_MH_LINKER = 15, // linkToCallSite_MH LF_GWC = 16, // guardWithCatch (catchException) LF_GWT = 17, // guardWithTest - LF_LIMIT = 18; + LF_TF = 18, // tryFinally + LF_LOOP = 19, // loop + LF_LIMIT = 20; /** Return the type corresponding uniquely (1-1) to this MT-form. * It might have any primitive returns or arguments, but will have no references except Object. diff --git a/jdk/test/java/lang/invoke/MethodHandlesTest.java b/jdk/test/java/lang/invoke/MethodHandlesTest.java index 3370767940b..0f4e7236c62 100644 --- a/jdk/test/java/lang/invoke/MethodHandlesTest.java +++ b/jdk/test/java/lang/invoke/MethodHandlesTest.java @@ -2792,7 +2792,7 @@ public class MethodHandlesTest { System.arraycopy(steps, 0, preSteps, 1, nargs); System.arraycopy(finis, 0, preFinis, 0, nargs); // finis are also offset by 1 for pre-checked loops // Convert to clause-major form. - MethodHandle[][] preClauses = new MethodHandle[nargs+1][4]; + MethodHandle[][] preClauses = new MethodHandle[nargs + 1][4]; MethodHandle[][] postClauses = new MethodHandle[nargs][4]; toClauseMajor(preClauses, preInits, preSteps, prePreds, preFinis); toClauseMajor(postClauses, inits, steps, usePreds, finis); From 9717ec036b85a6352eeda0c41e352024d91d1964 Mon Sep 17 00:00:00 2001 From: Bhanu Prakash Gopularam Date: Mon, 4 Jul 2016 10:50:28 +0000 Subject: [PATCH 122/125] 8159616: java.time.Instant falls through switch statement Removed the unneeded case statement INSTANT_SECONDS Reviewed-by: rriggs, scolebourne --- jdk/src/java.base/share/classes/java/time/Instant.java | 1 - 1 file changed, 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/time/Instant.java b/jdk/src/java.base/share/classes/java/time/Instant.java index 7f526e68c6b..3fd40d04d9c 100644 --- a/jdk/src/java.base/share/classes/java/time/Instant.java +++ b/jdk/src/java.base/share/classes/java/time/Instant.java @@ -561,7 +561,6 @@ public final class Instant case NANO_OF_SECOND: return nanos; case MICRO_OF_SECOND: return nanos / 1000; case MILLI_OF_SECOND: return nanos / 1000_000; - case INSTANT_SECONDS: INSTANT_SECONDS.checkValidIntValue(seconds); } throw new UnsupportedTemporalTypeException("Unsupported field: " + field); } From 7a41a43d840f23be8e3af8bd131143f10b5dfce5 Mon Sep 17 00:00:00 2001 From: Ivan Gerasimov Date: Mon, 4 Jul 2016 16:25:11 +0300 Subject: [PATCH 123/125] 8153948: sun/security/mscapi/ShortRSAKey1024.sh fails with "Field length overflow" Reviewed-by: coffeys, xuelei --- jdk/test/ProblemList.txt | 2 - .../security/mscapi/ShortRSAKeyWithinTLS.java | 86 +++++++++++++++++-- 2 files changed, 79 insertions(+), 9 deletions(-) diff --git a/jdk/test/ProblemList.txt b/jdk/test/ProblemList.txt index f46c820671e..0806355ff08 100644 --- a/jdk/test/ProblemList.txt +++ b/jdk/test/ProblemList.txt @@ -212,8 +212,6 @@ sun/security/krb5/auto/Unreachable.java 7164518 macosx-a sun/security/tools/keytool/ListKeychainStore.sh 8156889 macosx-all -sun/security/mscapi/ShortRSAKey1024.sh 8153948 windows-all - sun/security/tools/jarsigner/warnings/BadKeyUsageTest.java 8026393 generic-all sun/security/pkcs11/Cipher/ReinitCipher.java 8077138,8023434 windows-all diff --git a/jdk/test/sun/security/mscapi/ShortRSAKeyWithinTLS.java b/jdk/test/sun/security/mscapi/ShortRSAKeyWithinTLS.java index f2a752599eb..4a66abb290d 100644 --- a/jdk/test/sun/security/mscapi/ShortRSAKeyWithinTLS.java +++ b/jdk/test/sun/security/mscapi/ShortRSAKeyWithinTLS.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,7 +22,10 @@ */ import java.io.*; +import java.net.*; +import java.util.*; import java.security.*; +import java.security.cert.*; import javax.net.*; import javax.net.ssl.*; @@ -71,22 +74,34 @@ public class ShortRSAKeyWithinTLS { void doServerSide() throws Exception { // load the key store - KeyStore ks = KeyStore.getInstance("Windows-MY", "SunMSCAPI"); - ks.load(null, null); + serverKS = KeyStore.getInstance("Windows-MY", "SunMSCAPI"); + serverKS.load(null, null); System.out.println("Loaded keystore: Windows-MY"); // check key size - checkKeySize(ks); + checkKeySize(serverKS); // initialize the SSLContext KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509"); - kmf.init(ks, null); + kmf.init(serverKS, null); TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509"); - tmf.init(ks); + tmf.init(serverKS); + TrustManager[] tms = tmf.getTrustManagers(); + if (tms == null || tms.length == 0) { + throw new Exception("unexpected trust manager implementation"); + } else { + if (!(tms[0] instanceof X509TrustManager)) { + throw new Exception("unexpected trust manager" + + " implementation: " + + tms[0].getClass().getCanonicalName()); + } + } + serverTM = new MyExtendedX509TM((X509TrustManager)tms[0]); + tms = new TrustManager[] {serverTM}; SSLContext ctx = SSLContext.getInstance("TLS"); - ctx.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null); + ctx.init(kmf.getKeyManagers(), tms, null); ServerSocketFactory ssf = ctx.getServerSocketFactory(); SSLServerSocket sslServerSocket = (SSLServerSocket) @@ -228,6 +243,8 @@ public class ShortRSAKeyWithinTLS { Thread clientThread = null; Thread serverThread = null; + KeyStore serverKS; + MyExtendedX509TM serverTM; /* * Primary constructor, used to drive remainder of the test. @@ -348,5 +365,60 @@ public class ShortRSAKeyWithinTLS { } } } + + + class MyExtendedX509TM extends X509ExtendedTrustManager + implements X509TrustManager { + + X509TrustManager tm; + + MyExtendedX509TM(X509TrustManager tm) { + this.tm = tm; + } + + public void checkClientTrusted(X509Certificate chain[], String authType) + throws CertificateException { + tm.checkClientTrusted(chain, authType); + } + + public void checkServerTrusted(X509Certificate chain[], String authType) + throws CertificateException { + tm.checkServerTrusted(chain, authType); + } + + public X509Certificate[] getAcceptedIssuers() { + List certs = new ArrayList<>(); + try { + for (X509Certificate c : tm.getAcceptedIssuers()) { + if (serverKS.getCertificateAlias(c).equals(keyAlias)) + certs.add(c); + } + } catch (KeyStoreException kse) { + throw new RuntimeException(kse); + } + return certs.toArray(new X509Certificate[certs.size()]); + } + + public void checkClientTrusted(X509Certificate[] chain, String authType, + Socket socket) throws CertificateException { + tm.checkClientTrusted(chain, authType); + } + + public void checkServerTrusted(X509Certificate[] chain, String authType, + Socket socket) throws CertificateException { + tm.checkServerTrusted(chain, authType); + } + + public void checkClientTrusted(X509Certificate[] chain, String authType, + SSLEngine engine) throws CertificateException { + tm.checkClientTrusted(chain, authType); + } + + public void checkServerTrusted(X509Certificate[] chain, String authType, + SSLEngine engine) throws CertificateException { + tm.checkServerTrusted(chain, authType); + } + } + } From 9a3757b37ac785198d2771a562c5d8c1057f635f Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Mon, 4 Jul 2016 09:13:13 -0700 Subject: [PATCH 124/125] 8160698: java --dry-run should not cause main class be initialized Reviewed-by: ksrini --- .../classes/sun/launcher/LauncherHelper.java | 12 +++--- jdk/src/java.base/share/native/libjli/java.c | 35 +++++++++-------- .../launcher/modules/dryrun/DryRunTest.java | 17 ++++++++- .../src/test/jdk/test/MainWithClinit.java | 38 +++++++++++++++++++ 4 files changed, 81 insertions(+), 21 deletions(-) create mode 100644 jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/MainWithClinit.java diff --git a/jdk/src/java.base/share/classes/sun/launcher/LauncherHelper.java b/jdk/src/java.base/share/classes/sun/launcher/LauncherHelper.java index b1b761eb452..aff3778c7ff 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/LauncherHelper.java +++ b/jdk/src/java.base/share/classes/sun/launcher/LauncherHelper.java @@ -584,15 +584,17 @@ public final class LauncherHelper { Class mainClass = null; ClassLoader scl = ClassLoader.getSystemClassLoader(); try { - mainClass = scl.loadClass(cn); + mainClass = Class.forName(cn, false, scl); } catch (NoClassDefFoundError | ClassNotFoundException cnfe) { if (System.getProperty("os.name", "").contains("OS X") && Normalizer.isNormalized(cn, Normalizer.Form.NFD)) { try { - // On Mac OS X since all names with diacretic symbols are given as decomposed it - // is possible that main class name comes incorrectly from the command line - // and we have to re-compose it - mainClass = scl.loadClass(Normalizer.normalize(cn, Normalizer.Form.NFC)); + // On Mac OS X since all names with diacretic symbols are + // given as decomposed it is possible that main class name + // comes incorrectly from the command line and we have + // to re-compose it + String ncn = Normalizer.normalize(cn, Normalizer.Form.NFC); + mainClass = Class.forName(ncn, false, scl); } catch (NoClassDefFoundError | ClassNotFoundException cnfe1) { abort(cnfe, "java.launcher.cls.error1", cn); } diff --git a/jdk/src/java.base/share/native/libjli/java.c b/jdk/src/java.base/share/native/libjli/java.c index ffd60727128..5a5e8deac23 100644 --- a/jdk/src/java.base/share/native/libjli/java.c +++ b/jdk/src/java.base/share/native/libjli/java.c @@ -435,7 +435,8 @@ JavaMain(void * _args) ret = 1; /* - * Get the application's main class. + * Get the application's main class. It also checks if the main + * method exists. * * See bugid 5030265. The Main-Class name has already been parsed * from the manifest, but not parsed properly for UTF-8 support. @@ -467,6 +468,16 @@ JavaMain(void * _args) */ appClass = GetApplicationClass(env); NULL_CHECK_RETURN_VALUE(appClass, -1); + + /* Build platform specific argument array */ + mainArgs = CreateApplicationArgs(env, argv, argc); + CHECK_EXCEPTION_NULL_LEAVE(mainArgs); + + if (dryRun) { + ret = 0; + LEAVE(); + } + /* * PostJVMInit uses the class name as the application name for GUI purposes, * for example, on OSX this sets the application name in the menu bar for @@ -476,6 +487,7 @@ JavaMain(void * _args) */ PostJVMInit(env, appClass, vm); CHECK_EXCEPTION_LEAVE(1); + /* * The LoadMainClass not only loads the main class, it will also ensure * that the main method's signature is correct, therefore further checking @@ -486,22 +498,15 @@ JavaMain(void * _args) "([Ljava/lang/String;)V"); CHECK_EXCEPTION_NULL_LEAVE(mainID); - /* Build platform specific argument array */ - mainArgs = CreateApplicationArgs(env, argv, argc); - CHECK_EXCEPTION_NULL_LEAVE(mainArgs); + /* Invoke main method. */ + (*env)->CallStaticVoidMethod(env, mainClass, mainID, mainArgs); - if (dryRun) { - ret = 0; - } else { - /* Invoke main method. */ - (*env)->CallStaticVoidMethod(env, mainClass, mainID, mainArgs); + /* + * The launcher's exit code (in the absence of calls to + * System.exit) will be non-zero if main threw an exception. + */ + ret = (*env)->ExceptionOccurred(env) == NULL ? 0 : 1; - /* - * The launcher's exit code (in the absence of calls to - * System.exit) will be non-zero if main threw an exception. - */ - ret = (*env)->ExceptionOccurred(env) == NULL ? 0 : 1; - } LEAVE(); } diff --git a/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java index ca87bf88679..ca127d642d8 100644 --- a/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java +++ b/jdk/test/tools/launcher/modules/dryrun/DryRunTest.java @@ -60,6 +60,7 @@ public class DryRunTest { // the module main class private static final String MAIN_CLASS = "jdk.test.Main"; + private static final String MAIN_CLINIT_CLASS = "jdk.test.MainWithClinit"; @BeforeTest @@ -99,12 +100,26 @@ public class DryRunTest { String dir = MODS_DIR.toString(); String mid = TEST_MODULE + "/" + MAIN_CLASS; - // java -modulepath mods -module $TESTMODULE/$MAINCLASS // no resolution failure int exitValue = exec("--dry-run", "-modulepath", dir, "-m", mid); assertTrue(exitValue == 0); } + /** + * Test dryrun that does not invoke of the main class + */ + public void testMainClinit() throws Exception { + String dir = MODS_DIR.toString(); + String mid = TEST_MODULE + "/" + MAIN_CLINIT_CLASS; + + int exitValue = exec("--dry-run", "-modulepath", dir, "-m", mid); + assertTrue(exitValue == 0); + + // expect the test to fail if main class is initialized + exitValue = exec("-modulepath", dir, "-m", mid); + assertTrue(exitValue != 0); + } + /** * Test non-existence module in -addmods */ diff --git a/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/MainWithClinit.java b/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/MainWithClinit.java new file mode 100644 index 00000000000..9c2fcd3c204 --- /dev/null +++ b/jdk/test/tools/launcher/modules/dryrun/src/test/jdk/test/MainWithClinit.java @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code 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 + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package jdk.test; + +public class MainWithClinit { + static { + fail(); + } + + private static void fail() { + throw new RuntimeException("MainWithClinit:: invoked"); + } + + public static void main(String[] args) { + System.out.println("hi"); + } +} From bc8144c597ceb00239eb89b15294fd04aa901823 Mon Sep 17 00:00:00 2001 From: Masayoshi Okutsu Date: Tue, 5 Jul 2016 13:53:30 +0900 Subject: [PATCH 125/125] 8136356: Add time zone mappings on Windows Reviewed-by: peytoia --- jdk/src/java.base/windows/conf/tzmappings | 96 ++++++++++++++--------- 1 file changed, 60 insertions(+), 36 deletions(-) diff --git a/jdk/src/java.base/windows/conf/tzmappings b/jdk/src/java.base/windows/conf/tzmappings index 0a0b8ad4e0e..28917ae0cc9 100644 --- a/jdk/src/java.base/windows/conf/tzmappings +++ b/jdk/src/java.base/windows/conf/tzmappings @@ -164,39 +164,63 @@ Caucasus Standard Time:8,9:AM:Asia/Yerevan: GMT Standard Time:88,89::GMT: Greenwich:88,89::GMT: Greenwich Standard Time:88,89::GMT: -Argentina Standard Time:900,900::America/Buenos_Aires: -Azerbaijan Standard Time:901,901:AZ:Asia/Baku: -Bangladesh Standard Time:902,902::Asia/Dhaka: -Central Brazilian Standard Time:903,903:BR:America/Cuiaba: -Central Standard Time (Mexico):904,904::America/Mexico_City: -Georgian Standard Time:905,905:GE:Asia/Tbilisi: -Jordan Standard Time:906,906:JO:Asia/Amman: -Kamchatka Standard Time:907,907:RU:Asia/Kamchatka: -Mauritius Standard Time:908,908:MU:Indian/Mauritius: -Middle East Standard Time:909,909:LB:Asia/Beirut: -Montevideo Standard Time:910,910:UY:America/Montevideo: -Morocco Standard Time:911,911:MA:Africa/Casablanca: -Mountain Standard Time (Mexico):912,912:MX:America/Chihuahua: -Namibia Standard Time:913,913:NA:Africa/Windhoek: -Pacific Standard Time (Mexico):914,914:MX:America/Tijuana: -Pakistan Standard Time:915,915::Asia/Karachi: -Paraguay Standard Time:916,916:PY:America/Asuncion: -Syria Standard Time:917,917:SY:Asia/Damascus: -UTC:918,918::UTC: -UTC+12:919,919::GMT+1200: -UTC-02:920,920::GMT-0200: -UTC-11:921,921::GMT-1100: -Ulaanbaatar Standard Time:922,922::Asia/Ulaanbaatar: -Venezuela Standard Time:923,923::America/Caracas: -Magadan Standard Time:924,924::Asia/Magadan: -Kaliningrad Standard Time:925,925:RU:Europe/Kaliningrad: -Turkey Standard Time:926,926::Asia/Istanbul: -Bahia Standard Time:927,927::America/Bahia: -Libya Standard Time:928,928:LY:Africa/Tripoli: -Belarus Standard Time:929,929:BY:Europe/Minsk: -Line Islands Standard Time:930,930::Pacific/Kiritimati: -Russia Time Zone 10:931,931::Asia/Srednekolymsk: -Russia Time Zone 11:932,932::Asia/Anadyr: -Russia Time Zone 3:933,933::Europe/Samara: -Western Brazilian Standard Time:934,934:BR:America/Rio_Branco: -Armenian Standard Time:935,935:AM:Asia/Yerevan: +Aleutian Standard Time:900,900:US:America/Adak: +Altai Standard Time:901,901::Asia/Barnaul: +Argentina Standard Time:902,902::America/Buenos_Aires: +Armenian Standard Time:903,903:AM:Asia/Yerevan: +Astrakhan Standard Time:904,904::Europe/Astrakhan: +Aus Central W. Standard Time:905,905::Australia/Eucla: +Azerbaijan Standard Time:906,906:AZ:Asia/Baku: +Bahia Standard Time:907,907::America/Bahia: +Bangladesh Standard Time:908,908::Asia/Dhaka: +Belarus Standard Time:909,909:BY:Europe/Minsk: +Bougainville Standard Time:910,910::Pacific/Bougainville: +Central Brazilian Standard Time:911,911:BR:America/Cuiaba: +Central Standard Time (Mexico):912,912::America/Mexico_City: +Chatham Islands Standard Time:913,913::Pacific/Chatham: +Cuba Standard Time:914,914:CU:America/Havana: +Easter Island Standard Time:915,915:CL:Pacific/Easter: +Eastern Standard Time (Mexico):916,916::America/Cancun: +Georgian Standard Time:917,917:GE:Asia/Tbilisi: +Haiti Standard Time:918,918:HT:America/Port-au-Prince: +Jordan Standard Time:919,919:JO:Asia/Amman: +Kaliningrad Standard Time:920,920:RU:Europe/Kaliningrad: +Kamchatka Standard Time:921,921:RU:Asia/Kamchatka: +Libya Standard Time:922,922:LY:Africa/Tripoli: +Line Islands Standard Time:923,923::Pacific/Kiritimati: +Lord Howe Standard Time:924,924::Australia/Lord_Howe: +Magadan Standard Time:925,925::Asia/Magadan: +Marquesas Standard Time:926,926::Pacific/Marquesas: +Mauritius Standard Time:927,927:MU:Indian/Mauritius: +Middle East Standard Time:928,928:LB:Asia/Beirut: +Montevideo Standard Time:929,929:UY:America/Montevideo: +Morocco Standard Time:930,930:MA:Africa/Casablanca: +Mountain Standard Time (Mexico):931,931:MX:America/Chihuahua: +Namibia Standard Time:932,932:NA:Africa/Windhoek: +Norfolk Standard Time:933,933::Pacific/Norfolk: +North Korea Standard Time:934,934:KP:Asia/Pyongyang: +Pacific Standard Time (Mexico):935,935:MX:America/Tijuana: +Pakistan Standard Time:936,936::Asia/Karachi: +Paraguay Standard Time:937,937:PY:America/Asuncion: +Russia Time Zone 10:938,938::Asia/Srednekolymsk: +Russia Time Zone 11:939,939::Asia/Anadyr: +Russia Time Zone 3:940,940::Europe/Samara: +Saint Pierre Standard Time:941,941:PM:America/Miquelon: +Sakhalin Standard Time:942,942::Asia/Sakhalin: +Syria Standard Time:943,943:SY:Asia/Damascus: +Tocantins Standard Time:944,944::America/Araguaina: +Tomsk Standard Time:945,945::Asia/Tomsk: +Transbaikal Standard Time:946,946::Asia/Chita: +Turkey Standard Time:947,947::Asia/Istanbul: +Turks And Caicos Standard Time:948,948:TC:America/Grand_Turk: +UTC+12:949,949::GMT+1200: +UTC-02:950,950::GMT-0200: +UTC-08:951,951::GMT-0800: +UTC-09:952,952::GMT-0900: +UTC-11:953,953::GMT-1100: +UTC:954,954::UTC: +Ulaanbaatar Standard Time:955,955::Asia/Ulaanbaatar: +Venezuela Standard Time:956,956::America/Caracas: +W. Mongolia Standard Time:957,957::Asia/Hovd: +West Bank Standard Time:958,958::Asia/Gaza: +Western Brazilian Standard Time:959,959:BR:America/Rio_Branco: