Merge
This commit is contained in:
commit
ee8996368e
@ -277,3 +277,4 @@ ea2f7981236f3812436958748ab3d26e80a35130 jdk9-b28
|
||||
7e3512dae8e020d44399c0f1c579ff1fe3090ed6 jdk9-b32
|
||||
e4ba01b726e263953ae129be37c94de6ed145b1d jdk9-b33
|
||||
087b23f35631e68e950496a36fce8ccca612966a jdk9-b34
|
||||
c173ba994245380fb11ef077d1e59823386840eb jdk9-b35
|
||||
|
@ -277,3 +277,4 @@ c432b80aadd0cb2b2361b02add4d671957d4cec9 jdk9-b31
|
||||
b5b139354630edb2d06190bf31653acbdcea63a8 jdk9-b32
|
||||
cfdac5887952c2dd73c73a1d8d9aa880d0539bbf jdk9-b33
|
||||
24a0bad5910f775bb4002d1dacf8b3af87c63cd8 jdk9-b34
|
||||
9bc2dbd3dfb8c9fa88e00056b8b93a81ee6d306e jdk9-b35
|
||||
|
@ -437,3 +437,4 @@ deb29e92f68ace2808a36ecfa18c7d61dcb645bb jdk9-b29
|
||||
af46576a8d7cb4003028b8ee8bf408cfe227315b jdk9-b32
|
||||
9b3f5e4f33725f7c1d9b8e523133fe8383a54d9f jdk9-b33
|
||||
821164b0131a47ca065697c7d27d8f215e608c8d jdk9-b34
|
||||
438cb613151c4bd290bb732697517cba1cafcb04 jdk9-b35
|
||||
|
@ -67,7 +67,6 @@ MAPFILE = $(GAMMADIR)/make/aix/makefiles/mapfile-vers-debug
|
||||
# not justified.
|
||||
LFLAGS_QIPA=
|
||||
|
||||
G_SUFFIX = _g
|
||||
VERSION = optimized
|
||||
SYSDEFS += -DASSERT -DFASTDEBUG
|
||||
PICFLAGS = DEFAULT
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -82,6 +82,7 @@
|
||||
_JVM_EnableCompiler
|
||||
_JVM_Exit
|
||||
_JVM_FillInStackTrace
|
||||
_JVM_FindClassFromCaller
|
||||
_JVM_FindClassFromClass
|
||||
_JVM_FindClassFromClassLoader
|
||||
_JVM_FindClassFromBootLoader
|
||||
@ -115,7 +116,6 @@
|
||||
_JVM_GetClassDeclaredMethods
|
||||
_JVM_GetClassFieldsCount
|
||||
_JVM_GetClassInterfaces
|
||||
_JVM_GetClassLoader
|
||||
_JVM_GetClassMethodsCount
|
||||
_JVM_GetClassModifiers
|
||||
_JVM_GetClassName
|
||||
|
@ -82,6 +82,7 @@
|
||||
_JVM_EnableCompiler
|
||||
_JVM_Exit
|
||||
_JVM_FillInStackTrace
|
||||
_JVM_FindClassFromCaller
|
||||
_JVM_FindClassFromClass
|
||||
_JVM_FindClassFromClassLoader
|
||||
_JVM_FindClassFromBootLoader
|
||||
@ -115,7 +116,6 @@
|
||||
_JVM_GetClassDeclaredMethods
|
||||
_JVM_GetClassFieldsCount
|
||||
_JVM_GetClassInterfaces
|
||||
_JVM_GetClassLoader
|
||||
_JVM_GetClassMethodsCount
|
||||
_JVM_GetClassModifiers
|
||||
_JVM_GetClassName
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -84,6 +84,7 @@ SUNWprivate_1.1 {
|
||||
JVM_EnableCompiler;
|
||||
JVM_Exit;
|
||||
JVM_FillInStackTrace;
|
||||
JVM_FindClassFromCaller;
|
||||
JVM_FindClassFromClass;
|
||||
JVM_FindClassFromClassLoader;
|
||||
JVM_FindClassFromBootLoader;
|
||||
@ -117,7 +118,6 @@ SUNWprivate_1.1 {
|
||||
JVM_GetClassDeclaredMethods;
|
||||
JVM_GetClassFieldsCount;
|
||||
JVM_GetClassInterfaces;
|
||||
JVM_GetClassLoader;
|
||||
JVM_GetClassMethodsCount;
|
||||
JVM_GetClassModifiers;
|
||||
JVM_GetClassName;
|
||||
|
@ -268,8 +268,35 @@ class Assembler : public AbstractAssembler {
|
||||
|
||||
ISEL_OPCODE = (31u << OPCODE_SHIFT | 15u << 1),
|
||||
|
||||
MTLR_OPCODE = (31u << OPCODE_SHIFT | 467u << 1 | 8 << SPR_0_4_SHIFT),
|
||||
MFLR_OPCODE = (31u << OPCODE_SHIFT | 339u << 1 | 8 << SPR_0_4_SHIFT),
|
||||
// Special purpose registers
|
||||
MTSPR_OPCODE = (31u << OPCODE_SHIFT | 467u << 1),
|
||||
MFSPR_OPCODE = (31u << OPCODE_SHIFT | 339u << 1),
|
||||
|
||||
MTXER_OPCODE = (MTSPR_OPCODE | 1 << SPR_0_4_SHIFT),
|
||||
MFXER_OPCODE = (MFSPR_OPCODE | 1 << SPR_0_4_SHIFT),
|
||||
|
||||
MTDSCR_OPCODE = (MTSPR_OPCODE | 3 << SPR_0_4_SHIFT),
|
||||
MFDSCR_OPCODE = (MFSPR_OPCODE | 3 << SPR_0_4_SHIFT),
|
||||
|
||||
MTLR_OPCODE = (MTSPR_OPCODE | 8 << SPR_0_4_SHIFT),
|
||||
MFLR_OPCODE = (MFSPR_OPCODE | 8 << SPR_0_4_SHIFT),
|
||||
|
||||
MTCTR_OPCODE = (MTSPR_OPCODE | 9 << SPR_0_4_SHIFT),
|
||||
MFCTR_OPCODE = (MFSPR_OPCODE | 9 << SPR_0_4_SHIFT),
|
||||
|
||||
MTTFHAR_OPCODE = (MTSPR_OPCODE | 128 << SPR_0_4_SHIFT),
|
||||
MFTFHAR_OPCODE = (MFSPR_OPCODE | 128 << SPR_0_4_SHIFT),
|
||||
MTTFIAR_OPCODE = (MTSPR_OPCODE | 129 << SPR_0_4_SHIFT),
|
||||
MFTFIAR_OPCODE = (MFSPR_OPCODE | 129 << SPR_0_4_SHIFT),
|
||||
MTTEXASR_OPCODE = (MTSPR_OPCODE | 130 << SPR_0_4_SHIFT),
|
||||
MFTEXASR_OPCODE = (MFSPR_OPCODE | 130 << SPR_0_4_SHIFT),
|
||||
MTTEXASRU_OPCODE = (MTSPR_OPCODE | 131 << SPR_0_4_SHIFT),
|
||||
MFTEXASRU_OPCODE = (MFSPR_OPCODE | 131 << SPR_0_4_SHIFT),
|
||||
|
||||
MTVRSAVE_OPCODE = (MTSPR_OPCODE | 256 << SPR_0_4_SHIFT),
|
||||
MFVRSAVE_OPCODE = (MFSPR_OPCODE | 256 << SPR_0_4_SHIFT),
|
||||
|
||||
MFTB_OPCODE = (MFSPR_OPCODE | 268 << SPR_0_4_SHIFT),
|
||||
|
||||
MTCRF_OPCODE = (31u << OPCODE_SHIFT | 144u << 1),
|
||||
MFCR_OPCODE = (31u << OPCODE_SHIFT | 19u << 1),
|
||||
@ -291,9 +318,6 @@ class Assembler : public AbstractAssembler {
|
||||
|
||||
// CTR-related opcodes
|
||||
BCCTR_OPCODE = (19u << OPCODE_SHIFT | 528u << 1),
|
||||
MTCTR_OPCODE = (31u << OPCODE_SHIFT | 467u << 1 | 9 << SPR_0_4_SHIFT),
|
||||
MFCTR_OPCODE = (31u << OPCODE_SHIFT | 339u << 1 | 9 << SPR_0_4_SHIFT),
|
||||
|
||||
|
||||
LWZ_OPCODE = (32u << OPCODE_SHIFT),
|
||||
LWZX_OPCODE = (31u << OPCODE_SHIFT | 23u << 1),
|
||||
@ -585,6 +609,37 @@ class Assembler : public AbstractAssembler {
|
||||
MTVSCR_OPCODE = (4u << OPCODE_SHIFT | 1604u ),
|
||||
MFVSCR_OPCODE = (4u << OPCODE_SHIFT | 1540u ),
|
||||
|
||||
// AES (introduced with Power 8)
|
||||
VCIPHER_OPCODE = (4u << OPCODE_SHIFT | 1288u),
|
||||
VCIPHERLAST_OPCODE = (4u << OPCODE_SHIFT | 1289u),
|
||||
VNCIPHER_OPCODE = (4u << OPCODE_SHIFT | 1352u),
|
||||
VNCIPHERLAST_OPCODE = (4u << OPCODE_SHIFT | 1353u),
|
||||
VSBOX_OPCODE = (4u << OPCODE_SHIFT | 1480u),
|
||||
|
||||
// SHA (introduced with Power 8)
|
||||
VSHASIGMAD_OPCODE = (4u << OPCODE_SHIFT | 1730u),
|
||||
VSHASIGMAW_OPCODE = (4u << OPCODE_SHIFT | 1666u),
|
||||
|
||||
// Vector Binary Polynomial Multiplication (introduced with Power 8)
|
||||
VPMSUMB_OPCODE = (4u << OPCODE_SHIFT | 1032u),
|
||||
VPMSUMD_OPCODE = (4u << OPCODE_SHIFT | 1224u),
|
||||
VPMSUMH_OPCODE = (4u << OPCODE_SHIFT | 1096u),
|
||||
VPMSUMW_OPCODE = (4u << OPCODE_SHIFT | 1160u),
|
||||
|
||||
// Vector Permute and Xor (introduced with Power 8)
|
||||
VPERMXOR_OPCODE = (4u << OPCODE_SHIFT | 45u),
|
||||
|
||||
// Transactional Memory instructions (introduced with Power 8)
|
||||
TBEGIN_OPCODE = (31u << OPCODE_SHIFT | 654u << 1),
|
||||
TEND_OPCODE = (31u << OPCODE_SHIFT | 686u << 1),
|
||||
TABORT_OPCODE = (31u << OPCODE_SHIFT | 910u << 1),
|
||||
TABORTWC_OPCODE = (31u << OPCODE_SHIFT | 782u << 1),
|
||||
TABORTWCI_OPCODE = (31u << OPCODE_SHIFT | 846u << 1),
|
||||
TABORTDC_OPCODE = (31u << OPCODE_SHIFT | 814u << 1),
|
||||
TABORTDCI_OPCODE = (31u << OPCODE_SHIFT | 878u << 1),
|
||||
TSR_OPCODE = (31u << OPCODE_SHIFT | 750u << 1),
|
||||
TCHECK_OPCODE = (31u << OPCODE_SHIFT | 718u << 1),
|
||||
|
||||
// Icache and dcache related instructions
|
||||
DCBA_OPCODE = (31u << OPCODE_SHIFT | 758u << 1),
|
||||
DCBZ_OPCODE = (31u << OPCODE_SHIFT | 1014u << 1),
|
||||
@ -1420,6 +1475,25 @@ class Assembler : public AbstractAssembler {
|
||||
inline void mcrf( ConditionRegister crd, ConditionRegister cra);
|
||||
inline void mtcr( Register s);
|
||||
|
||||
// Special purpose registers
|
||||
// Exception Register
|
||||
inline void mtxer(Register s1);
|
||||
inline void mfxer(Register d);
|
||||
// Vector Register Save Register
|
||||
inline void mtvrsave(Register s1);
|
||||
inline void mfvrsave(Register d);
|
||||
// Timebase
|
||||
inline void mftb(Register d);
|
||||
// Introduced with Power 8:
|
||||
// Data Stream Control Register
|
||||
inline void mtdscr(Register s1);
|
||||
inline void mfdscr(Register d );
|
||||
// Transactional Memory Registers
|
||||
inline void mftfhar(Register d);
|
||||
inline void mftfiar(Register d);
|
||||
inline void mftexasr(Register d);
|
||||
inline void mftexasru(Register d);
|
||||
|
||||
// PPC 1, section 2.4.1 Branch Instructions
|
||||
inline void b( address a, relocInfo::relocType rt = relocInfo::none);
|
||||
inline void b( Label& L);
|
||||
@ -1860,6 +1934,39 @@ class Assembler : public AbstractAssembler {
|
||||
inline void mtvscr( VectorRegister b);
|
||||
inline void mfvscr( VectorRegister d);
|
||||
|
||||
// AES (introduced with Power 8)
|
||||
inline void vcipher( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vcipherlast( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vncipher( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vncipherlast(VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vsbox( VectorRegister d, VectorRegister a);
|
||||
|
||||
// SHA (introduced with Power 8)
|
||||
// Not yet implemented.
|
||||
|
||||
// Vector Binary Polynomial Multiplication (introduced with Power 8)
|
||||
inline void vpmsumb( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vpmsumd( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vpmsumh( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
inline void vpmsumw( VectorRegister d, VectorRegister a, VectorRegister b);
|
||||
|
||||
// Vector Permute and Xor (introduced with Power 8)
|
||||
inline void vpermxor( VectorRegister d, VectorRegister a, VectorRegister b, VectorRegister c);
|
||||
|
||||
// Transactional Memory instructions (introduced with Power 8)
|
||||
inline void tbegin_(); // R=0
|
||||
inline void tbeginrot_(); // R=1 Rollback-Only Transaction
|
||||
inline void tend_(); // A=0
|
||||
inline void tendall_(); // A=1
|
||||
inline void tabort_(Register a);
|
||||
inline void tabortwc_(int t, Register a, Register b);
|
||||
inline void tabortwci_(int t, Register a, int si);
|
||||
inline void tabortdc_(int t, Register a, Register b);
|
||||
inline void tabortdci_(int t, Register a, int si);
|
||||
inline void tsuspend_(); // tsr with L=0
|
||||
inline void tresume_(); // tsr with L=1
|
||||
inline void tcheck(int f);
|
||||
|
||||
// The following encoders use r0 as second operand. These instructions
|
||||
// read r0 as '0'.
|
||||
inline void lwzx( Register d, Register s2);
|
||||
|
@ -312,6 +312,25 @@ inline void Assembler::mcrf( ConditionRegister crd, ConditionRegister cra)
|
||||
{ emit_int32(MCRF_OPCODE | bf(crd) | bfa(cra)); }
|
||||
inline void Assembler::mtcr( Register s) { Assembler::mtcrf(0xff, s); }
|
||||
|
||||
// Special purpose registers
|
||||
// Exception Register
|
||||
inline void Assembler::mtxer(Register s1) { emit_int32(MTXER_OPCODE | rs(s1)); }
|
||||
inline void Assembler::mfxer(Register d ) { emit_int32(MFXER_OPCODE | rt(d)); }
|
||||
// Vector Register Save Register
|
||||
inline void Assembler::mtvrsave(Register s1) { emit_int32(MTVRSAVE_OPCODE | rs(s1)); }
|
||||
inline void Assembler::mfvrsave(Register d ) { emit_int32(MFVRSAVE_OPCODE | rt(d)); }
|
||||
// Timebase
|
||||
inline void Assembler::mftb(Register d ) { emit_int32(MFTB_OPCODE | rt(d)); }
|
||||
// Introduced with Power 8:
|
||||
// Data Stream Control Register
|
||||
inline void Assembler::mtdscr(Register s1) { emit_int32(MTDSCR_OPCODE | rs(s1)); }
|
||||
inline void Assembler::mfdscr(Register d ) { emit_int32(MFDSCR_OPCODE | rt(d)); }
|
||||
// Transactional Memory Registers
|
||||
inline void Assembler::mftfhar(Register d ) { emit_int32(MFTFHAR_OPCODE | rt(d)); }
|
||||
inline void Assembler::mftfiar(Register d ) { emit_int32(MFTFIAR_OPCODE | rt(d)); }
|
||||
inline void Assembler::mftexasr(Register d ) { emit_int32(MFTEXASR_OPCODE | rt(d)); }
|
||||
inline void Assembler::mftexasru(Register d ) { emit_int32(MFTEXASRU_OPCODE | rt(d)); }
|
||||
|
||||
// SAP JVM 2006-02-13 PPC branch instruction.
|
||||
// PPC 1, section 2.4.1 Branch Instructions
|
||||
inline void Assembler::b( address a, relocInfo::relocType rt) { emit_data(BXX_OPCODE| li(disp( intptr_t(a), intptr_t(pc()))) |aa(0)|lk(0), rt); }
|
||||
@ -735,6 +754,39 @@ inline void Assembler::vsrah( VectorRegister d, VectorRegister a, VectorRegist
|
||||
inline void Assembler::mtvscr( VectorRegister b) { emit_int32( MTVSCR_OPCODE | vrb(b)); }
|
||||
inline void Assembler::mfvscr( VectorRegister d) { emit_int32( MFVSCR_OPCODE | vrt(d)); }
|
||||
|
||||
// AES (introduced with Power 8)
|
||||
inline void Assembler::vcipher( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VCIPHER_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vcipherlast( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VCIPHERLAST_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vncipher( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VNCIPHER_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vncipherlast(VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VNCIPHERLAST_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vsbox( VectorRegister d, VectorRegister a) { emit_int32( VSBOX_OPCODE | vrt(d) | vra(a) ); }
|
||||
|
||||
// SHA (introduced with Power 8)
|
||||
// Not yet implemented.
|
||||
|
||||
// Vector Binary Polynomial Multiplication (introduced with Power 8)
|
||||
inline void Assembler::vpmsumb( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPMSUMB_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vpmsumd( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPMSUMD_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vpmsumh( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPMSUMH_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
inline void Assembler::vpmsumw( VectorRegister d, VectorRegister a, VectorRegister b) { emit_int32( VPMSUMW_OPCODE | vrt(d) | vra(a) | vrb(b)); }
|
||||
|
||||
// Vector Permute and Xor (introduced with Power 8)
|
||||
inline void Assembler::vpermxor( VectorRegister d, VectorRegister a, VectorRegister b, VectorRegister c) { emit_int32( VPMSUMW_OPCODE | vrt(d) | vra(a) | vrb(b) | vrc(c)); }
|
||||
|
||||
// Transactional Memory instructions (introduced with Power 8)
|
||||
inline void Assembler::tbegin_() { emit_int32( TBEGIN_OPCODE | rc(1)); }
|
||||
inline void Assembler::tbeginrot_() { emit_int32( TBEGIN_OPCODE | /*R=1*/ 1u << (31-10) | rc(1)); }
|
||||
inline void Assembler::tend_() { emit_int32( TEND_OPCODE | rc(1)); }
|
||||
inline void Assembler::tendall_() { emit_int32( TEND_OPCODE | /*A=1*/ 1u << (31-6) | rc(1)); }
|
||||
inline void Assembler::tabort_(Register a) { emit_int32( TABORT_OPCODE | ra(a) | rc(1)); }
|
||||
inline void Assembler::tabortwc_(int t, Register a, Register b) { emit_int32( TABORTWC_OPCODE | to(t) | ra(a) | rb(b) | rc(1)); }
|
||||
inline void Assembler::tabortwci_(int t, Register a, int si) { emit_int32( TABORTWCI_OPCODE | to(t) | ra(a) | sh1620(si) | rc(1)); }
|
||||
inline void Assembler::tabortdc_(int t, Register a, Register b) { emit_int32( TABORTDC_OPCODE | to(t) | ra(a) | rb(b) | rc(1)); }
|
||||
inline void Assembler::tabortdci_(int t, Register a, int si) { emit_int32( TABORTDCI_OPCODE | to(t) | ra(a) | sh1620(si) | rc(1)); }
|
||||
inline void Assembler::tsuspend_() { emit_int32( TSR_OPCODE | rc(1)); }
|
||||
inline void Assembler::tresume_() { emit_int32( TSR_OPCODE | /*L=1*/ 1u << (31-10) | rc(1)); }
|
||||
inline void Assembler::tcheck(int f) { emit_int32( TCHECK_OPCODE | bf(f)); }
|
||||
|
||||
// ra0 version
|
||||
inline void Assembler::lwzx( Register d, Register s2) { emit_int32( LWZX_OPCODE | rt(d) | rb(s2));}
|
||||
inline void Assembler::lwz( Register d, int si16 ) { emit_int32( LWZ_OPCODE | rt(d) | d1(si16));}
|
||||
|
@ -37,6 +37,8 @@ const int StackAlignmentInBytes = 16;
|
||||
// signatures accordingly.
|
||||
const bool CCallingConventionRequiresIntsAsLongs = true;
|
||||
|
||||
#define SUPPORTS_NATIVE_CX8
|
||||
|
||||
// The PPC CPUs are NOT multiple-copy-atomic.
|
||||
#define CPU_NOT_MULTIPLE_COPY_ATOMIC
|
||||
|
||||
|
@ -25,7 +25,6 @@
|
||||
|
||||
|
||||
#include "precompiled.hpp"
|
||||
#include "asm/assembler.hpp"
|
||||
#include "asm/macroAssembler.inline.hpp"
|
||||
#include "interp_masm_ppc_64.hpp"
|
||||
#include "interpreter/interpreterRuntime.hpp"
|
||||
|
@ -24,7 +24,6 @@
|
||||
*/
|
||||
|
||||
#include "precompiled.hpp"
|
||||
#include "asm/assembler.hpp"
|
||||
#include "asm/macroAssembler.inline.hpp"
|
||||
#include "interpreter/bytecodeHistogram.hpp"
|
||||
#include "interpreter/interpreter.hpp"
|
||||
|
@ -2366,7 +2366,7 @@ void MacroAssembler::g1_write_barrier_post(Register Rstore_addr, Register Rnew_v
|
||||
#endif // INCLUDE_ALL_GCS
|
||||
|
||||
// Values for last_Java_pc, and last_Java_sp must comply to the rules
|
||||
// in frame_ppc64.hpp.
|
||||
// in frame_ppc.hpp.
|
||||
void MacroAssembler::set_last_Java_frame(Register last_Java_sp, Register last_Java_pc) {
|
||||
// Always set last_Java_pc and flags first because once last_Java_sp
|
||||
// is visible has_last_Java_frame is true and users will look at the
|
||||
@ -2493,6 +2493,7 @@ int MacroAssembler::instr_size_for_decode_klass_not_null() {
|
||||
}
|
||||
|
||||
void MacroAssembler::decode_klass_not_null(Register dst, Register src) {
|
||||
assert(dst != R0, "Dst reg may not be R0, as R0 is used here.");
|
||||
if (src == noreg) src = dst;
|
||||
Register shifted_src = src;
|
||||
if (Universe::narrow_klass_shift() != 0 ||
|
||||
@ -2527,14 +2528,11 @@ void MacroAssembler::load_klass_with_trap_null_check(Register dst, Register src)
|
||||
|
||||
void MacroAssembler::reinit_heapbase(Register d, Register tmp) {
|
||||
if (Universe::heap() != NULL) {
|
||||
if (Universe::narrow_oop_base() == NULL) {
|
||||
Assembler::xorr(R30, R30, R30);
|
||||
} else {
|
||||
load_const(R30, Universe::narrow_ptrs_base(), tmp);
|
||||
}
|
||||
load_const_optimized(R30, Universe::narrow_ptrs_base(), tmp);
|
||||
} else {
|
||||
load_const(R30, Universe::narrow_ptrs_base_addr(), tmp);
|
||||
ld(R30, 0, R30);
|
||||
// Heap not yet allocated. Load indirectly.
|
||||
int simm16_offset = load_const_optimized(R30, Universe::narrow_ptrs_base_addr(), tmp, true);
|
||||
ld(R30, simm16_offset, R30);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1249,6 +1249,7 @@ EmitCallOffsets emit_call_with_trampoline_stub(MacroAssembler &_masm, address en
|
||||
|
||||
// Emit the trampoline stub which will be related to the branch-and-link below.
|
||||
CallStubImpl::emit_trampoline_stub(_masm, entry_point_toc_offset, offsets.insts_call_instruction_offset);
|
||||
if (Compile::current()->env()->failing()) { return offsets; } // Code cache may be full.
|
||||
__ relocate(rtype);
|
||||
}
|
||||
|
||||
@ -1410,7 +1411,7 @@ void MachPrologNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
|
||||
while (bang_offset <= bang_end) {
|
||||
// Need at least one stack bang at end of shadow zone.
|
||||
|
||||
// Again I had to copy code, this time from assembler_ppc64.cpp,
|
||||
// Again I had to copy code, this time from assembler_ppc.cpp,
|
||||
// bang_stack_with_offset - see there for comments.
|
||||
|
||||
// Stack grows down, caller passes positive offset.
|
||||
@ -2000,7 +2001,7 @@ void MachUEPNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
|
||||
|
||||
// Inline_cache contains a klass.
|
||||
Register ic_klass = as_Register(Matcher::inline_cache_reg_encode());
|
||||
Register receiver_klass = R0; // tmp
|
||||
Register receiver_klass = R12_scratch2; // tmp
|
||||
|
||||
assert_different_registers(ic_klass, receiver_klass, R11_scratch1, R3_ARG1);
|
||||
assert(R11_scratch1 == R11, "need prologue scratch register");
|
||||
@ -3484,6 +3485,7 @@ encode %{
|
||||
|
||||
// Emit the trampoline stub which will be related to the branch-and-link below.
|
||||
CallStubImpl::emit_trampoline_stub(_masm, entry_point_toc_offset, start_offset);
|
||||
if (Compile::current()->env()->failing()) { return; } // Code cache may be full.
|
||||
__ relocate(_optimized_virtual ?
|
||||
relocInfo::opt_virtual_call_type : relocInfo::static_call_type);
|
||||
}
|
||||
@ -3527,6 +3529,7 @@ encode %{
|
||||
|
||||
// Emit the trampoline stub which will be related to the branch-and-link below.
|
||||
CallStubImpl::emit_trampoline_stub(_masm, entry_point_toc_offset, start_offset);
|
||||
if (ra_->C->env()->failing()) { return; } // Code cache may be full.
|
||||
assert(_optimized_virtual, "methodHandle call should be a virtual call");
|
||||
__ relocate(relocInfo::opt_virtual_call_type);
|
||||
}
|
||||
@ -3577,9 +3580,7 @@ encode %{
|
||||
const address entry_point_const = __ address_constant(entry_point, RelocationHolder::none);
|
||||
const int entry_point_const_toc_offset = __ offset_to_method_toc(entry_point_const);
|
||||
CallStubImpl::emit_trampoline_stub(_masm, entry_point_const_toc_offset, __ offset());
|
||||
|
||||
if (ra_->C->env()->failing())
|
||||
return;
|
||||
if (ra_->C->env()->failing()) { return; } // Code cache may be full.
|
||||
|
||||
// Build relocation at call site with ic position as data.
|
||||
assert((_load_ic_hi_node != NULL && _load_ic_node == NULL) ||
|
||||
@ -5638,19 +5639,6 @@ instruct loadNKlass(iRegNdst dst, memory mem) %{
|
||||
ins_pipe(pipe_class_memory);
|
||||
%}
|
||||
|
||||
//// Load compressed klass and decode it if narrow_klass_shift == 0.
|
||||
//// TODO: will narrow_klass_shift ever be 0?
|
||||
//instruct decodeNKlass2Klass(iRegPdst dst, memory mem) %{
|
||||
// match(Set dst (DecodeNKlass (LoadNKlass mem)));
|
||||
// predicate(false /* TODO: PPC port Universe::narrow_klass_shift() == 0*);
|
||||
// ins_cost(MEMORY_REF_COST);
|
||||
//
|
||||
// format %{ "LWZ $dst, $mem \t// DecodeNKlass (unscaled)" %}
|
||||
// size(4);
|
||||
// ins_encode( enc_lwz(dst, mem) );
|
||||
// ins_pipe(pipe_class_memory);
|
||||
//%}
|
||||
|
||||
// Load Klass Pointer
|
||||
instruct loadKlass(iRegPdst dst, memoryAlg4 mem) %{
|
||||
match(Set dst (LoadKlass mem));
|
||||
@ -6070,11 +6058,15 @@ instruct loadConN_Ex(iRegNdst dst, immN src) %{
|
||||
%}
|
||||
%}
|
||||
|
||||
instruct loadConNKlass_hi(iRegNdst dst, immNKlass src) %{
|
||||
// We have seen a safepoint between the hi and lo parts, and this node was handled
|
||||
// as an oop. Therefore this needs a match rule so that build_oop_map knows this is
|
||||
// not a narrow oop.
|
||||
instruct loadConNKlass_hi(iRegNdst dst, immNKlass_NM src) %{
|
||||
match(Set dst src);
|
||||
effect(DEF dst, USE src);
|
||||
ins_cost(DEFAULT_COST);
|
||||
|
||||
format %{ "LIS $dst, $src \t// narrow oop hi" %}
|
||||
format %{ "LIS $dst, $src \t// narrow klass hi" %}
|
||||
size(4);
|
||||
ins_encode %{
|
||||
// TODO: PPC port $archOpcode(ppc64Opcode_addis);
|
||||
@ -6084,6 +6076,21 @@ instruct loadConNKlass_hi(iRegNdst dst, immNKlass src) %{
|
||||
ins_pipe(pipe_class_default);
|
||||
%}
|
||||
|
||||
// As loadConNKlass_hi this must be recognized as narrow klass, not oop!
|
||||
instruct loadConNKlass_mask(iRegNdst dst, immNKlass_NM src1, iRegNsrc src2) %{
|
||||
match(Set dst src1);
|
||||
effect(TEMP src2);
|
||||
ins_cost(DEFAULT_COST);
|
||||
|
||||
format %{ "MASK $dst, $src2, 0xFFFFFFFF" %} // mask
|
||||
size(4);
|
||||
ins_encode %{
|
||||
// TODO: PPC port $archOpcode(ppc64Opcode_rldicl);
|
||||
__ clrldi($dst$$Register, $src2$$Register, 0x20);
|
||||
%}
|
||||
ins_pipe(pipe_class_default);
|
||||
%}
|
||||
|
||||
// This needs a match rule so that build_oop_map knows this is
|
||||
// not a narrow oop.
|
||||
instruct loadConNKlass_lo(iRegNdst dst, immNKlass_NM src1, iRegNsrc src2) %{
|
||||
@ -6091,10 +6098,10 @@ instruct loadConNKlass_lo(iRegNdst dst, immNKlass_NM src1, iRegNsrc src2) %{
|
||||
effect(TEMP src2);
|
||||
ins_cost(DEFAULT_COST);
|
||||
|
||||
format %{ "ADDI $dst, $src1, $src2 \t// narrow oop lo" %}
|
||||
format %{ "ORI $dst, $src1, $src2 \t// narrow klass lo" %}
|
||||
size(4);
|
||||
ins_encode %{
|
||||
// TODO: PPC port $archOpcode(ppc64Opcode_addi);
|
||||
// TODO: PPC port $archOpcode(ppc64Opcode_ori);
|
||||
intptr_t Csrc = Klass::encode_klass((Klass *)$src1$$constant);
|
||||
assert(__ oop_recorder() != NULL, "this assembler needs an OopRecorder");
|
||||
int klass_index = __ oop_recorder()->find_index((Klass *)$src1$$constant);
|
||||
@ -6125,10 +6132,11 @@ instruct loadConNKlass_Ex(iRegNdst dst, immNKlass src) %{
|
||||
MachNode *m2 = m1;
|
||||
if (!Assembler::is_uimm((jlong)Klass::encode_klass((Klass *)op_src->constant()), 31)) {
|
||||
// Value might be 1-extended. Mask out these bits.
|
||||
m2 = new clearMs32bNode();
|
||||
m2 = new loadConNKlass_maskNode();
|
||||
m2->add_req(NULL, m1);
|
||||
m2->_opnds[0] = op_dst;
|
||||
m2->_opnds[1] = op_dst;
|
||||
m2->_opnds[1] = op_src;
|
||||
m2->_opnds[2] = op_dst;
|
||||
ra_->set_pair(m2->_idx, ra_->get_reg_second(this), ra_->get_reg_first(this));
|
||||
nodes->push(m2);
|
||||
}
|
||||
@ -6973,7 +6981,7 @@ instruct encodePKlass_32GAligned(iRegNdst dst, iRegPsrc src) %{
|
||||
size(4);
|
||||
ins_encode %{
|
||||
// TODO: PPC port $archOpcode(ppc64Opcode_rldicl);
|
||||
__ rldicl($dst$$Register, $src$$Register, 64-Universe::narrow_oop_shift(), 32);
|
||||
__ rldicl($dst$$Register, $src$$Register, 64-Universe::narrow_klass_shift(), 32);
|
||||
%}
|
||||
ins_pipe(pipe_class_default);
|
||||
%}
|
||||
|
@ -24,7 +24,6 @@
|
||||
*/
|
||||
|
||||
#include "precompiled.hpp"
|
||||
#include "asm/assembler.hpp"
|
||||
#include "asm/macroAssembler.inline.hpp"
|
||||
#include "interpreter/interpreter.hpp"
|
||||
#include "nativeInst_ppc.hpp"
|
||||
@ -39,9 +38,6 @@
|
||||
#include "runtime/stubCodeGenerator.hpp"
|
||||
#include "runtime/stubRoutines.hpp"
|
||||
#include "utilities/top.hpp"
|
||||
#ifdef COMPILER2
|
||||
#include "opto/runtime.hpp"
|
||||
#endif
|
||||
#include "runtime/thread.inline.hpp"
|
||||
|
||||
#define __ _masm->
|
||||
@ -216,7 +212,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||
{
|
||||
BLOCK_COMMENT("Call frame manager or native entry.");
|
||||
// Call frame manager or native entry.
|
||||
Register r_new_arg_entry = R14; // PPC_state;
|
||||
Register r_new_arg_entry = R14;
|
||||
assert_different_registers(r_new_arg_entry, r_top_of_arguments_addr,
|
||||
r_arg_method, r_arg_thread);
|
||||
|
||||
|
@ -353,7 +353,6 @@ void TemplateTable::ldc(bool wide) {
|
||||
__ sldi(Rscratch1, Rscratch1, LogBytesPerWord);
|
||||
__ cmpdi(CCR0, Rscratch2, JVM_CONSTANT_Integer);
|
||||
__ bne(CCR0, notInt);
|
||||
__ isync(); // Order load of constant wrt. tags.
|
||||
__ lwax(R17_tos, Rcpool, Rscratch1);
|
||||
__ push(itos);
|
||||
__ b(exit);
|
||||
@ -365,7 +364,6 @@ void TemplateTable::ldc(bool wide) {
|
||||
__ cmpdi(CCR0, Rscratch2, JVM_CONSTANT_Float);
|
||||
__ asm_assert_eq("unexpected type", 0x8765);
|
||||
#endif
|
||||
__ isync(); // Order load of constant wrt. tags.
|
||||
__ lfsx(F15_ftos, Rcpool, Rscratch1);
|
||||
__ push(ftos);
|
||||
|
||||
@ -424,13 +422,11 @@ void TemplateTable::ldc2_w() {
|
||||
// Check out Conversions.java for an example.
|
||||
// Also ConstantPool::header_size() is 20, which makes it very difficult
|
||||
// to double-align double on the constant pool. SG, 11/7/97
|
||||
__ isync(); // Order load of constant wrt. tags.
|
||||
__ lfdx(F15_ftos, Rcpool, Rindex);
|
||||
__ push(dtos);
|
||||
__ b(Lexit);
|
||||
|
||||
__ bind(Llong);
|
||||
__ isync(); // Order load of constant wrt. tags.
|
||||
__ ldx(R17_tos, Rcpool, Rindex);
|
||||
__ push(ltos);
|
||||
|
||||
|
@ -1020,7 +1020,3 @@ void PerfMemory::detach(char* addr, size_t bytes, TRAPS) {
|
||||
|
||||
unmap_shared(addr, bytes);
|
||||
}
|
||||
|
||||
char* PerfMemory::backing_store_filename() {
|
||||
return backing_store_file_name;
|
||||
}
|
||||
|
@ -1043,7 +1043,3 @@ void PerfMemory::detach(char* addr, size_t bytes, TRAPS) {
|
||||
|
||||
unmap_shared(addr, bytes);
|
||||
}
|
||||
|
||||
char* PerfMemory::backing_store_filename() {
|
||||
return backing_store_file_name;
|
||||
}
|
||||
|
@ -1049,7 +1049,3 @@ void PerfMemory::detach(char* addr, size_t bytes, TRAPS) {
|
||||
|
||||
unmap_shared(addr, bytes);
|
||||
}
|
||||
|
||||
char* PerfMemory::backing_store_filename() {
|
||||
return backing_store_file_name;
|
||||
}
|
||||
|
@ -1068,7 +1068,3 @@ void PerfMemory::detach(char* addr, size_t bytes, TRAPS) {
|
||||
|
||||
unmap_shared(addr, bytes);
|
||||
}
|
||||
|
||||
char* PerfMemory::backing_store_filename() {
|
||||
return backing_store_file_name;
|
||||
}
|
||||
|
@ -1846,7 +1846,3 @@ void PerfMemory::detach(char* addr, size_t bytes, TRAPS) {
|
||||
remove_file_mapping(addr);
|
||||
}
|
||||
}
|
||||
|
||||
char* PerfMemory::backing_store_filename() {
|
||||
return sharedmem_fileName;
|
||||
}
|
||||
|
@ -47,4 +47,4 @@ inline void Prefetch::write(void *loc, intx interval) {
|
||||
);
|
||||
}
|
||||
|
||||
#endif // OS_CPU_LINUX_PPC_VM_PREFETCH_LINUX_OJDKPPC_HPP
|
||||
#endif // OS_CPU_LINUX_PPC_VM_PREFETCH_LINUX_PPC_INLINE_HPP
|
||||
|
@ -2069,14 +2069,14 @@ void LIRGenerator::do_UnsafeGetRaw(UnsafeGetRaw* x) {
|
||||
LIR_Opr base_op = base.result();
|
||||
LIR_Opr index_op = idx.result();
|
||||
#ifndef _LP64
|
||||
if (x->base()->type()->tag() == longTag) {
|
||||
if (base_op->type() == T_LONG) {
|
||||
base_op = new_register(T_INT);
|
||||
__ convert(Bytecodes::_l2i, base.result(), base_op);
|
||||
}
|
||||
if (x->has_index()) {
|
||||
if (x->index()->type()->tag() == longTag) {
|
||||
if (index_op->type() == T_LONG) {
|
||||
LIR_Opr long_index_op = index_op;
|
||||
if (x->index()->type()->is_constant()) {
|
||||
if (index_op->is_constant()) {
|
||||
long_index_op = new_register(T_LONG);
|
||||
__ move(index_op, long_index_op);
|
||||
}
|
||||
@ -2091,14 +2091,14 @@ void LIRGenerator::do_UnsafeGetRaw(UnsafeGetRaw* x) {
|
||||
assert(!x->has_index() || index_op->type() == T_INT, "index should be an int");
|
||||
#else
|
||||
if (x->has_index()) {
|
||||
if (x->index()->type()->tag() == intTag) {
|
||||
if (!x->index()->type()->is_constant()) {
|
||||
if (index_op->type() == T_INT) {
|
||||
if (!index_op->is_constant()) {
|
||||
index_op = new_register(T_LONG);
|
||||
__ convert(Bytecodes::_i2l, idx.result(), index_op);
|
||||
}
|
||||
} else {
|
||||
assert(x->index()->type()->tag() == longTag, "must be");
|
||||
if (x->index()->type()->is_constant()) {
|
||||
assert(index_op->type() == T_LONG, "must be");
|
||||
if (index_op->is_constant()) {
|
||||
index_op = new_register(T_LONG);
|
||||
__ move(idx.result(), index_op);
|
||||
}
|
||||
@ -2179,12 +2179,12 @@ void LIRGenerator::do_UnsafePutRaw(UnsafePutRaw* x) {
|
||||
LIR_Opr index_op = idx.result();
|
||||
|
||||
#ifndef _LP64
|
||||
if (x->base()->type()->tag() == longTag) {
|
||||
if (base_op->type() == T_LONG) {
|
||||
base_op = new_register(T_INT);
|
||||
__ convert(Bytecodes::_l2i, base.result(), base_op);
|
||||
}
|
||||
if (x->has_index()) {
|
||||
if (x->index()->type()->tag() == longTag) {
|
||||
if (index_op->type() == T_LONG) {
|
||||
index_op = new_register(T_INT);
|
||||
__ convert(Bytecodes::_l2i, idx.result(), index_op);
|
||||
}
|
||||
@ -2194,7 +2194,7 @@ void LIRGenerator::do_UnsafePutRaw(UnsafePutRaw* x) {
|
||||
assert(!x->has_index() || (index_op->type() == T_INT && !index_op->is_constant()), "index should be an non-constant int");
|
||||
#else
|
||||
if (x->has_index()) {
|
||||
if (x->index()->type()->tag() == intTag) {
|
||||
if (index_op->type() == T_INT) {
|
||||
index_op = new_register(T_LONG);
|
||||
__ convert(Bytecodes::_i2l, idx.result(), index_op);
|
||||
}
|
||||
|
@ -2859,6 +2859,11 @@ void ClassFileParser::parse_classfile_bootstrap_methods_attribute(u4 attribute_b
|
||||
"bootstrap_method_index %u has bad constant type in class file %s",
|
||||
bootstrap_method_index,
|
||||
CHECK);
|
||||
|
||||
guarantee_property((operand_fill_index + 1 + argument_count) < operands->length(),
|
||||
"Invalid BootstrapMethods num_bootstrap_methods or num_bootstrap_arguments value in class file %s",
|
||||
CHECK);
|
||||
|
||||
operands->at_put(operand_fill_index++, bootstrap_method_index);
|
||||
operands->at_put(operand_fill_index++, argument_count);
|
||||
|
||||
@ -2875,8 +2880,6 @@ void ClassFileParser::parse_classfile_bootstrap_methods_attribute(u4 attribute_b
|
||||
}
|
||||
}
|
||||
|
||||
assert(ConstantPool::operand_array_length(operands) == attribute_array_length, "correct decode");
|
||||
|
||||
u1* current_end = cfs->current();
|
||||
guarantee_property(current_end == current_start + attribute_byte_length,
|
||||
"Bad length on BootstrapMethods in class file %s",
|
||||
|
@ -75,6 +75,7 @@ typedef jzentry* (JNICALL *FindEntry_t)(jzfile *zip, const char *name, jint *siz
|
||||
typedef jboolean (JNICALL *ReadEntry_t)(jzfile *zip, jzentry *entry, unsigned char *buf, char *namebuf);
|
||||
typedef jboolean (JNICALL *ReadMappedEntry_t)(jzfile *zip, jzentry *entry, unsigned char **buf, char *namebuf);
|
||||
typedef jzentry* (JNICALL *GetNextEntry_t)(jzfile *zip, jint n);
|
||||
typedef jint (JNICALL *Crc32_t)(jint crc, const jbyte *buf, jint len);
|
||||
|
||||
static ZipOpen_t ZipOpen = NULL;
|
||||
static ZipClose_t ZipClose = NULL;
|
||||
@ -83,6 +84,7 @@ static ReadEntry_t ReadEntry = NULL;
|
||||
static ReadMappedEntry_t ReadMappedEntry = NULL;
|
||||
static GetNextEntry_t GetNextEntry = NULL;
|
||||
static canonicalize_fn_t CanonicalizeEntry = NULL;
|
||||
static Crc32_t Crc32 = NULL;
|
||||
|
||||
// Globals
|
||||
|
||||
@ -799,9 +801,11 @@ void ClassLoader::load_zip_library() {
|
||||
ReadEntry = CAST_TO_FN_PTR(ReadEntry_t, os::dll_lookup(handle, "ZIP_ReadEntry"));
|
||||
ReadMappedEntry = CAST_TO_FN_PTR(ReadMappedEntry_t, os::dll_lookup(handle, "ZIP_ReadMappedEntry"));
|
||||
GetNextEntry = CAST_TO_FN_PTR(GetNextEntry_t, os::dll_lookup(handle, "ZIP_GetNextEntry"));
|
||||
Crc32 = CAST_TO_FN_PTR(Crc32_t, os::dll_lookup(handle, "ZIP_CRC32"));
|
||||
|
||||
// ZIP_Close is not exported on Windows in JDK5.0 so don't abort if ZIP_Close is NULL
|
||||
if (ZipOpen == NULL || FindEntry == NULL || ReadEntry == NULL || GetNextEntry == NULL) {
|
||||
if (ZipOpen == NULL || FindEntry == NULL || ReadEntry == NULL ||
|
||||
GetNextEntry == NULL || Crc32 == NULL) {
|
||||
vm_exit_during_initialization("Corrupted ZIP library", path);
|
||||
}
|
||||
|
||||
@ -811,6 +815,11 @@ void ClassLoader::load_zip_library() {
|
||||
// This lookup only works on 1.3. Do not check for non-null here
|
||||
}
|
||||
|
||||
int ClassLoader::crc32(int crc, const char* buf, int len) {
|
||||
assert(Crc32 != NULL, "ZIP_CRC32 is not found");
|
||||
return (*Crc32)(crc, (const jbyte*)buf, len);
|
||||
}
|
||||
|
||||
// PackageInfo data exists in order to support the java.lang.Package
|
||||
// class. A Package object provides information about a java package
|
||||
// (version, vendor, etc.) which originates in the manifest of the jar
|
||||
|
@ -226,6 +226,7 @@ class ClassLoader: AllStatic {
|
||||
// to avoid confusing the zip library
|
||||
static bool get_canonical_path(const char* orig, char* out, int len);
|
||||
public:
|
||||
static int crc32(int crc, const char* buf, int len);
|
||||
static bool update_class_path_entry_list(const char *path,
|
||||
bool check_for_duplicates,
|
||||
bool throw_exception=true);
|
||||
|
@ -148,7 +148,7 @@ int StackMapFrame::is_assignable_to(
|
||||
VerificationType* from, VerificationType* to, int32_t len, TRAPS) const {
|
||||
int32_t i = 0;
|
||||
for (i = 0; i < len; i++) {
|
||||
if (!to[i].is_assignable_from(from[i], verifier(), THREAD)) {
|
||||
if (!to[i].is_assignable_from(from[i], verifier(), false, THREAD)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -245,7 +245,7 @@ VerificationType StackMapFrame::pop_stack_ex(VerificationType type, TRAPS) {
|
||||
}
|
||||
VerificationType top = _stack[--_stack_size];
|
||||
bool subtype = type.is_assignable_from(
|
||||
top, verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
top, verifier(), false, CHECK_(VerificationType::bogus_type()));
|
||||
if (!subtype) {
|
||||
verifier()->verify_error(
|
||||
ErrorContext::bad_type(_offset, stack_top_ctx(),
|
||||
@ -265,7 +265,7 @@ VerificationType StackMapFrame::get_local(
|
||||
return VerificationType::bogus_type();
|
||||
}
|
||||
bool subtype = type.is_assignable_from(_locals[index],
|
||||
verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
verifier(), false, CHECK_(VerificationType::bogus_type()));
|
||||
if (!subtype) {
|
||||
verifier()->verify_error(
|
||||
ErrorContext::bad_type(_offset,
|
||||
@ -288,14 +288,14 @@ void StackMapFrame::get_local_2(
|
||||
"get long/double overflows locals");
|
||||
return;
|
||||
}
|
||||
bool subtype = type1.is_assignable_from(_locals[index], verifier(), CHECK);
|
||||
bool subtype = type1.is_assignable_from(_locals[index], verifier(), false, CHECK);
|
||||
if (!subtype) {
|
||||
verifier()->verify_error(
|
||||
ErrorContext::bad_type(_offset,
|
||||
TypeOrigin::local(index, this), TypeOrigin::implicit(type1)),
|
||||
"Bad local variable type");
|
||||
} else {
|
||||
subtype = type2.is_assignable_from(_locals[index + 1], verifier(), CHECK);
|
||||
subtype = type2.is_assignable_from(_locals[index + 1], verifier(), false, CHECK);
|
||||
if (!subtype) {
|
||||
/* Unreachable? All local store routines convert a split long or double
|
||||
* into a TOP during the store. So we should never end up seeing an
|
||||
|
@ -234,7 +234,7 @@ class StackMapFrame : public ResourceObj {
|
||||
if (_stack_size != 0) {
|
||||
VerificationType top = _stack[_stack_size - 1];
|
||||
bool subtype = type.is_assignable_from(
|
||||
top, verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
top, verifier(), false, CHECK_(VerificationType::bogus_type()));
|
||||
if (subtype) {
|
||||
--_stack_size;
|
||||
return top;
|
||||
@ -249,9 +249,9 @@ class StackMapFrame : public ResourceObj {
|
||||
assert(type2.is_long() || type2.is_double(), "must be long/double_2");
|
||||
if (_stack_size >= 2) {
|
||||
VerificationType top1 = _stack[_stack_size - 1];
|
||||
bool subtype1 = type1.is_assignable_from(top1, verifier(), CHECK);
|
||||
bool subtype1 = type1.is_assignable_from(top1, verifier(), false, CHECK);
|
||||
VerificationType top2 = _stack[_stack_size - 2];
|
||||
bool subtype2 = type2.is_assignable_from(top2, verifier(), CHECK);
|
||||
bool subtype2 = type2.is_assignable_from(top2, verifier(), false, CHECK);
|
||||
if (subtype1 && subtype2) {
|
||||
_stack_size -= 2;
|
||||
return;
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2003, 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
|
||||
@ -42,7 +42,8 @@ VerificationType VerificationType::from_tag(u1 tag) {
|
||||
}
|
||||
|
||||
bool VerificationType::is_reference_assignable_from(
|
||||
const VerificationType& from, ClassVerifier* context, TRAPS) const {
|
||||
const VerificationType& from, ClassVerifier* context,
|
||||
bool from_field_is_protected, TRAPS) const {
|
||||
instanceKlassHandle klass = context->current_class();
|
||||
if (from.is_null()) {
|
||||
// null is assignable to any reference
|
||||
@ -62,9 +63,11 @@ bool VerificationType::is_reference_assignable_from(
|
||||
Handle(THREAD, klass->protection_domain()), true, CHECK_false);
|
||||
KlassHandle this_class(THREAD, obj);
|
||||
|
||||
if (this_class->is_interface()) {
|
||||
// We treat interfaces as java.lang.Object, including
|
||||
// java.lang.Cloneable and java.io.Serializable
|
||||
if (this_class->is_interface() && (!from_field_is_protected ||
|
||||
from.name() != vmSymbols::java_lang_Object())) {
|
||||
// If we are not trying to access a protected field or method in
|
||||
// java.lang.Object then we treat interfaces as java.lang.Object,
|
||||
// including java.lang.Cloneable and java.io.Serializable.
|
||||
return true;
|
||||
} else if (from.is_object()) {
|
||||
Klass* from_class = SystemDictionary::resolve_or_fail(
|
||||
@ -76,7 +79,8 @@ bool VerificationType::is_reference_assignable_from(
|
||||
VerificationType comp_this = get_component(context, CHECK_false);
|
||||
VerificationType comp_from = from.get_component(context, CHECK_false);
|
||||
if (!comp_this.is_bogus() && !comp_from.is_bogus()) {
|
||||
return comp_this.is_assignable_from(comp_from, context, CHECK_false);
|
||||
return comp_this.is_assignable_from(comp_from, context,
|
||||
from_field_is_protected, CHECK_false);
|
||||
}
|
||||
}
|
||||
return false;
|
||||
|
@ -265,7 +265,8 @@ class VerificationType VALUE_OBJ_CLASS_SPEC {
|
||||
// is assignable to another. Returns true if one can assign 'from' to
|
||||
// this.
|
||||
bool is_assignable_from(
|
||||
const VerificationType& from, ClassVerifier* context, TRAPS) const {
|
||||
const VerificationType& from, ClassVerifier* context,
|
||||
bool from_field_is_protected, TRAPS) const {
|
||||
if (equals(from) || is_bogus()) {
|
||||
return true;
|
||||
} else {
|
||||
@ -286,7 +287,9 @@ class VerificationType VALUE_OBJ_CLASS_SPEC {
|
||||
return from.is_integer();
|
||||
default:
|
||||
if (is_reference() && from.is_reference()) {
|
||||
return is_reference_assignable_from(from, context, CHECK_false);
|
||||
return is_reference_assignable_from(from, context,
|
||||
from_field_is_protected,
|
||||
CHECK_false);
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
@ -308,7 +311,8 @@ class VerificationType VALUE_OBJ_CLASS_SPEC {
|
||||
private:
|
||||
|
||||
bool is_reference_assignable_from(
|
||||
const VerificationType&, ClassVerifier*, TRAPS) const;
|
||||
const VerificationType&, ClassVerifier*, bool from_field_is_protected,
|
||||
TRAPS) const;
|
||||
};
|
||||
|
||||
#endif // SHARE_VM_CLASSFILE_VERIFICATIONTYPE_HPP
|
||||
|
@ -98,6 +98,14 @@ bool Verifier::verify(instanceKlassHandle klass, Verifier::Mode mode, bool shoul
|
||||
HandleMark hm;
|
||||
ResourceMark rm(THREAD);
|
||||
|
||||
if (!is_eligible_for_verification(klass, should_verify_class)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// If the class should be verified, first see if we can use the split
|
||||
// verifier. If not, or if verification fails and FailOverToOldVerifier
|
||||
// is set, then call the inference verifier.
|
||||
|
||||
Symbol* exception_name = NULL;
|
||||
const size_t message_buffer_len = klass->name()->utf8_length() + 1024;
|
||||
char* message_buffer = NEW_RESOURCE_ARRAY(char, message_buffer_len);
|
||||
@ -105,47 +113,42 @@ bool Verifier::verify(instanceKlassHandle klass, Verifier::Mode mode, bool shoul
|
||||
|
||||
const char* klassName = klass->external_name();
|
||||
bool can_failover = FailOverToOldVerifier &&
|
||||
klass->major_version() < NOFAILOVER_MAJOR_VERSION;
|
||||
klass->major_version() < NOFAILOVER_MAJOR_VERSION;
|
||||
|
||||
// If the class should be verified, first see if we can use the split
|
||||
// verifier. If not, or if verification fails and FailOverToOldVerifier
|
||||
// is set, then call the inference verifier.
|
||||
if (is_eligible_for_verification(klass, should_verify_class)) {
|
||||
if (TraceClassInitialization) {
|
||||
tty->print_cr("Start class verification for: %s", klassName);
|
||||
}
|
||||
if (klass->major_version() >= STACKMAP_ATTRIBUTE_MAJOR_VERSION) {
|
||||
ClassVerifier split_verifier(klass, THREAD);
|
||||
split_verifier.verify_class(THREAD);
|
||||
exception_name = split_verifier.result();
|
||||
if (can_failover && !HAS_PENDING_EXCEPTION &&
|
||||
(exception_name == vmSymbols::java_lang_VerifyError() ||
|
||||
exception_name == vmSymbols::java_lang_ClassFormatError())) {
|
||||
if (TraceClassInitialization || VerboseVerification) {
|
||||
tty->print_cr(
|
||||
"Fail over class verification to old verifier for: %s", klassName);
|
||||
}
|
||||
exception_name = inference_verify(
|
||||
klass, message_buffer, message_buffer_len, THREAD);
|
||||
if (TraceClassInitialization) {
|
||||
tty->print_cr("Start class verification for: %s", klassName);
|
||||
}
|
||||
if (klass->major_version() >= STACKMAP_ATTRIBUTE_MAJOR_VERSION) {
|
||||
ClassVerifier split_verifier(klass, THREAD);
|
||||
split_verifier.verify_class(THREAD);
|
||||
exception_name = split_verifier.result();
|
||||
if (can_failover && !HAS_PENDING_EXCEPTION &&
|
||||
(exception_name == vmSymbols::java_lang_VerifyError() ||
|
||||
exception_name == vmSymbols::java_lang_ClassFormatError())) {
|
||||
if (TraceClassInitialization || VerboseVerification) {
|
||||
tty->print_cr(
|
||||
"Fail over class verification to old verifier for: %s", klassName);
|
||||
}
|
||||
if (exception_name != NULL) {
|
||||
exception_message = split_verifier.exception_message();
|
||||
}
|
||||
} else {
|
||||
exception_name = inference_verify(
|
||||
klass, message_buffer, message_buffer_len, THREAD);
|
||||
klass, message_buffer, message_buffer_len, THREAD);
|
||||
}
|
||||
if (exception_name != NULL) {
|
||||
exception_message = split_verifier.exception_message();
|
||||
}
|
||||
} else {
|
||||
exception_name = inference_verify(
|
||||
klass, message_buffer, message_buffer_len, THREAD);
|
||||
}
|
||||
|
||||
if (TraceClassInitialization || VerboseVerification) {
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
tty->print("Verification for %s has", klassName);
|
||||
tty->print_cr(" exception pending %s ",
|
||||
InstanceKlass::cast(PENDING_EXCEPTION->klass())->external_name());
|
||||
} else if (exception_name != NULL) {
|
||||
tty->print_cr("Verification for %s failed", klassName);
|
||||
}
|
||||
tty->print_cr("End class verification for: %s", klassName);
|
||||
if (TraceClassInitialization || VerboseVerification) {
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
tty->print("Verification for %s has", klassName);
|
||||
tty->print_cr(" exception pending %s ",
|
||||
InstanceKlass::cast(PENDING_EXCEPTION->klass())->external_name());
|
||||
} else if (exception_name != NULL) {
|
||||
tty->print_cr("Verification for %s failed", klassName);
|
||||
}
|
||||
tty->print_cr("End class verification for: %s", klassName);
|
||||
}
|
||||
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
@ -1718,7 +1721,7 @@ void ClassVerifier::verify_exception_handler_table(u4 code_length, char* code_da
|
||||
VerificationType throwable =
|
||||
VerificationType::reference_type(vmSymbols::java_lang_Throwable());
|
||||
bool is_subclass = throwable.is_assignable_from(
|
||||
catch_type, this, CHECK_VERIFY(this));
|
||||
catch_type, this, false, CHECK_VERIFY(this));
|
||||
if (!is_subclass) {
|
||||
// 4286534: should throw VerifyError according to recent spec change
|
||||
verify_error(ErrorContext::bad_type(handler_pc,
|
||||
@ -2171,7 +2174,7 @@ void ClassVerifier::verify_field_instructions(RawBytecodeStream* bcs,
|
||||
stack_object_type = current_type();
|
||||
}
|
||||
is_assignable = target_class_type.is_assignable_from(
|
||||
stack_object_type, this, CHECK_VERIFY(this));
|
||||
stack_object_type, this, false, CHECK_VERIFY(this));
|
||||
if (!is_assignable) {
|
||||
verify_error(ErrorContext::bad_type(bci,
|
||||
current_frame->stack_top_ctx(),
|
||||
@ -2198,7 +2201,7 @@ void ClassVerifier::verify_field_instructions(RawBytecodeStream* bcs,
|
||||
// It's protected access, check if stack object is assignable to
|
||||
// current class.
|
||||
is_assignable = current_type().is_assignable_from(
|
||||
stack_object_type, this, CHECK_VERIFY(this));
|
||||
stack_object_type, this, true, CHECK_VERIFY(this));
|
||||
if (!is_assignable) {
|
||||
verify_error(ErrorContext::bad_type(bci,
|
||||
current_frame->stack_top_ctx(),
|
||||
@ -2472,7 +2475,7 @@ void ClassVerifier::verify_invoke_init(
|
||||
instanceKlassHandle mh(THREAD, m->method_holder());
|
||||
if (m->is_protected() && !mh->is_same_class_package(_klass())) {
|
||||
bool assignable = current_type().is_assignable_from(
|
||||
objectref_type, this, CHECK_VERIFY(this));
|
||||
objectref_type, this, true, CHECK_VERIFY(this));
|
||||
if (!assignable) {
|
||||
verify_error(ErrorContext::bad_type(bci,
|
||||
TypeOrigin::cp(new_class_index, objectref_type),
|
||||
@ -2643,11 +2646,11 @@ void ClassVerifier::verify_invoke_instructions(
|
||||
bool have_imr_indirect = cp->tag_at(index).value() == JVM_CONSTANT_InterfaceMethodref;
|
||||
if (!current_class()->is_anonymous()) {
|
||||
subtype = ref_class_type.is_assignable_from(
|
||||
current_type(), this, CHECK_VERIFY(this));
|
||||
current_type(), this, false, CHECK_VERIFY(this));
|
||||
} else {
|
||||
VerificationType host_klass_type =
|
||||
VerificationType::reference_type(current_class()->host_klass()->name());
|
||||
subtype = ref_class_type.is_assignable_from(host_klass_type, this, CHECK_VERIFY(this));
|
||||
subtype = ref_class_type.is_assignable_from(host_klass_type, this, false, CHECK_VERIFY(this));
|
||||
|
||||
// If invokespecial of IMR, need to recheck for same or
|
||||
// direct interface relative to the host class
|
||||
@ -2691,7 +2694,7 @@ void ClassVerifier::verify_invoke_instructions(
|
||||
VerificationType top = current_frame->pop_stack(CHECK_VERIFY(this));
|
||||
VerificationType hosttype =
|
||||
VerificationType::reference_type(current_class()->host_klass()->name());
|
||||
bool subtype = hosttype.is_assignable_from(top, this, CHECK_VERIFY(this));
|
||||
bool subtype = hosttype.is_assignable_from(top, this, false, CHECK_VERIFY(this));
|
||||
if (!subtype) {
|
||||
verify_error( ErrorContext::bad_type(current_frame->offset(),
|
||||
current_frame->stack_top_ctx(),
|
||||
@ -2716,7 +2719,7 @@ void ClassVerifier::verify_invoke_instructions(
|
||||
// It's protected access, check if stack object is
|
||||
// assignable to current class.
|
||||
bool is_assignable = current_type().is_assignable_from(
|
||||
stack_object_type, this, CHECK_VERIFY(this));
|
||||
stack_object_type, this, true, CHECK_VERIFY(this));
|
||||
if (!is_assignable) {
|
||||
if (ref_class_type.name() == vmSymbols::java_lang_Object()
|
||||
&& stack_object_type.is_array()
|
||||
@ -2899,7 +2902,7 @@ void ClassVerifier::verify_return_value(
|
||||
"Method expects a return value");
|
||||
return;
|
||||
}
|
||||
bool match = return_type.is_assignable_from(type, this, CHECK_VERIFY(this));
|
||||
bool match = return_type.is_assignable_from(type, this, false, CHECK_VERIFY(this));
|
||||
if (!match) {
|
||||
verify_error(ErrorContext::bad_type(bci,
|
||||
current_frame->stack_top_ctx(), TypeOrigin::signature(return_type)),
|
||||
|
@ -254,8 +254,7 @@ bool CodeCache::heap_available(int code_blob_type) {
|
||||
if (!SegmentedCodeCache) {
|
||||
// No segmentation: use a single code heap
|
||||
return (code_blob_type == CodeBlobType::All);
|
||||
} else if ((Arguments::mode() == Arguments::_int) ||
|
||||
(TieredStopAtLevel == CompLevel_none)) {
|
||||
} else if (Arguments::mode() == Arguments::_int) {
|
||||
// Interpreter only: we don't need any method code heaps
|
||||
return (code_blob_type == CodeBlobType::NonNMethod);
|
||||
} else if (TieredCompilation && (TieredStopAtLevel > CompLevel_simple)) {
|
||||
|
@ -1683,6 +1683,8 @@ protected:
|
||||
int _failures;
|
||||
bool _verbose;
|
||||
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1ParVerifyFinalCountTask(G1CollectedHeap* g1h,
|
||||
BitMap* region_bm, BitMap* card_bm,
|
||||
@ -1692,19 +1694,8 @@ public:
|
||||
_actual_region_bm(region_bm), _actual_card_bm(card_bm),
|
||||
_expected_region_bm(expected_region_bm), _expected_card_bm(expected_card_bm),
|
||||
_failures(0), _verbose(false),
|
||||
_n_workers(0) {
|
||||
_n_workers(_g1h->workers()->active_workers()), _hrclaimer(_n_workers) {
|
||||
assert(VerifyDuringGC, "don't call this otherwise");
|
||||
|
||||
// Use the value already set as the number of active threads
|
||||
// in the call to run_task().
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
assert( _g1h->workers()->active_workers() > 0,
|
||||
"Should have been previously set");
|
||||
_n_workers = _g1h->workers()->active_workers();
|
||||
} else {
|
||||
_n_workers = 1;
|
||||
}
|
||||
|
||||
assert(_expected_card_bm->size() == _actual_card_bm->size(), "sanity");
|
||||
assert(_expected_region_bm->size() == _actual_region_bm->size(), "sanity");
|
||||
|
||||
@ -1721,10 +1712,7 @@ public:
|
||||
_verbose);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
_g1h->heap_region_par_iterate_chunked(&verify_cl,
|
||||
worker_id,
|
||||
_n_workers,
|
||||
HeapRegion::VerifyCountClaimValue);
|
||||
_g1h->heap_region_par_iterate(&verify_cl, worker_id, &_hrclaimer);
|
||||
} else {
|
||||
_g1h->heap_region_iterate(&verify_cl);
|
||||
}
|
||||
@ -1813,22 +1801,14 @@ protected:
|
||||
BitMap* _actual_card_bm;
|
||||
|
||||
uint _n_workers;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1ParFinalCountTask(G1CollectedHeap* g1h, BitMap* region_bm, BitMap* card_bm)
|
||||
: AbstractGangTask("G1 final counting"),
|
||||
_g1h(g1h), _cm(_g1h->concurrent_mark()),
|
||||
_actual_region_bm(region_bm), _actual_card_bm(card_bm),
|
||||
_n_workers(0) {
|
||||
// Use the value already set as the number of active threads
|
||||
// in the call to run_task().
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
assert( _g1h->workers()->active_workers() > 0,
|
||||
"Should have been previously set");
|
||||
_n_workers = _g1h->workers()->active_workers();
|
||||
} else {
|
||||
_n_workers = 1;
|
||||
}
|
||||
_n_workers(_g1h->workers()->active_workers()), _hrclaimer(_n_workers) {
|
||||
}
|
||||
|
||||
void work(uint worker_id) {
|
||||
@ -1839,10 +1819,7 @@ public:
|
||||
_actual_card_bm);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
_g1h->heap_region_par_iterate_chunked(&final_update_cl,
|
||||
worker_id,
|
||||
_n_workers,
|
||||
HeapRegion::FinalCountClaimValue);
|
||||
_g1h->heap_region_par_iterate(&final_update_cl, worker_id, &_hrclaimer);
|
||||
} else {
|
||||
_g1h->heap_region_iterate(&final_update_cl);
|
||||
}
|
||||
@ -1929,12 +1906,12 @@ protected:
|
||||
size_t _max_live_bytes;
|
||||
size_t _freed_bytes;
|
||||
FreeRegionList* _cleanup_list;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1ParNoteEndTask(G1CollectedHeap* g1h,
|
||||
FreeRegionList* cleanup_list) :
|
||||
AbstractGangTask("G1 note end"), _g1h(g1h),
|
||||
_max_live_bytes(0), _freed_bytes(0), _cleanup_list(cleanup_list) { }
|
||||
G1ParNoteEndTask(G1CollectedHeap* g1h, FreeRegionList* cleanup_list, uint n_workers) :
|
||||
AbstractGangTask("G1 note end"), _g1h(g1h), _max_live_bytes(0), _freed_bytes(0), _cleanup_list(cleanup_list), _hrclaimer(n_workers) {
|
||||
}
|
||||
|
||||
void work(uint worker_id) {
|
||||
double start = os::elapsedTime();
|
||||
@ -1943,9 +1920,7 @@ public:
|
||||
G1NoteEndOfConcMarkClosure g1_note_end(_g1h, &local_cleanup_list,
|
||||
&hrrs_cleanup_task);
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
_g1h->heap_region_par_iterate_chunked(&g1_note_end, worker_id,
|
||||
_g1h->workers()->active_workers(),
|
||||
HeapRegion::NoteEndClaimValue);
|
||||
_g1h->heap_region_par_iterate(&g1_note_end, worker_id, &_hrclaimer);
|
||||
} else {
|
||||
_g1h->heap_region_iterate(&g1_note_end);
|
||||
}
|
||||
@ -1991,16 +1966,16 @@ protected:
|
||||
G1RemSet* _g1rs;
|
||||
BitMap* _region_bm;
|
||||
BitMap* _card_bm;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1ParScrubRemSetTask(G1CollectedHeap* g1h,
|
||||
BitMap* region_bm, BitMap* card_bm) :
|
||||
AbstractGangTask("G1 ScrubRS"), _g1rs(g1h->g1_rem_set()),
|
||||
_region_bm(region_bm), _card_bm(card_bm) { }
|
||||
G1ParScrubRemSetTask(G1CollectedHeap* g1h, BitMap* region_bm, BitMap* card_bm, uint n_workers) :
|
||||
AbstractGangTask("G1 ScrubRS"), _g1rs(g1h->g1_rem_set()), _region_bm(region_bm), _card_bm(card_bm), _hrclaimer(n_workers) {
|
||||
}
|
||||
|
||||
void work(uint worker_id) {
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
_g1rs->scrub_par(_region_bm, _card_bm, worker_id,
|
||||
HeapRegion::ScrubRemSetClaimValue);
|
||||
_g1rs->scrub_par(_region_bm, _card_bm, worker_id, &_hrclaimer);
|
||||
} else {
|
||||
_g1rs->scrub(_region_bm, _card_bm);
|
||||
}
|
||||
@ -2043,9 +2018,6 @@ void ConcurrentMark::cleanup() {
|
||||
G1ParFinalCountTask g1_par_count_task(g1h, &_region_bm, &_card_bm);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
assert(g1h->check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
|
||||
g1h->set_par_threads();
|
||||
n_workers = g1h->n_par_threads();
|
||||
assert(g1h->n_par_threads() == n_workers,
|
||||
@ -2053,9 +2025,6 @@ void ConcurrentMark::cleanup() {
|
||||
g1h->workers()->run_task(&g1_par_count_task);
|
||||
// Done with the parallel phase so reset to 0.
|
||||
g1h->set_par_threads(0);
|
||||
|
||||
assert(g1h->check_heap_region_claim_values(HeapRegion::FinalCountClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
n_workers = 1;
|
||||
g1_par_count_task.work(0);
|
||||
@ -2080,9 +2049,6 @@ void ConcurrentMark::cleanup() {
|
||||
g1h->workers()->run_task(&g1_par_verify_task);
|
||||
// Done with the parallel phase so reset to 0.
|
||||
g1h->set_par_threads(0);
|
||||
|
||||
assert(g1h->check_heap_region_claim_values(HeapRegion::VerifyCountClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
g1_par_verify_task.work(0);
|
||||
}
|
||||
@ -2108,14 +2074,11 @@ void ConcurrentMark::cleanup() {
|
||||
g1h->reset_gc_time_stamp();
|
||||
|
||||
// Note end of marking in all heap regions.
|
||||
G1ParNoteEndTask g1_par_note_end_task(g1h, &_cleanup_list);
|
||||
G1ParNoteEndTask g1_par_note_end_task(g1h, &_cleanup_list, n_workers);
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
g1h->set_par_threads((int)n_workers);
|
||||
g1h->workers()->run_task(&g1_par_note_end_task);
|
||||
g1h->set_par_threads(0);
|
||||
|
||||
assert(g1h->check_heap_region_claim_values(HeapRegion::NoteEndClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
g1_par_note_end_task.work(0);
|
||||
}
|
||||
@ -2132,15 +2095,11 @@ void ConcurrentMark::cleanup() {
|
||||
// regions.
|
||||
if (G1ScrubRemSets) {
|
||||
double rs_scrub_start = os::elapsedTime();
|
||||
G1ParScrubRemSetTask g1_par_scrub_rs_task(g1h, &_region_bm, &_card_bm);
|
||||
G1ParScrubRemSetTask g1_par_scrub_rs_task(g1h, &_region_bm, &_card_bm, n_workers);
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
g1h->set_par_threads((int)n_workers);
|
||||
g1h->workers()->run_task(&g1_par_scrub_rs_task);
|
||||
g1h->set_par_threads(0);
|
||||
|
||||
assert(g1h->check_heap_region_claim_values(
|
||||
HeapRegion::ScrubRemSetClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
g1_par_scrub_rs_task.work(0);
|
||||
}
|
||||
@ -3288,6 +3247,7 @@ protected:
|
||||
BitMap* _cm_card_bm;
|
||||
uint _max_worker_id;
|
||||
int _active_workers;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1AggregateCountDataTask(G1CollectedHeap* g1h,
|
||||
@ -3295,18 +3255,18 @@ public:
|
||||
BitMap* cm_card_bm,
|
||||
uint max_worker_id,
|
||||
int n_workers) :
|
||||
AbstractGangTask("Count Aggregation"),
|
||||
_g1h(g1h), _cm(cm), _cm_card_bm(cm_card_bm),
|
||||
_max_worker_id(max_worker_id),
|
||||
_active_workers(n_workers) { }
|
||||
AbstractGangTask("Count Aggregation"),
|
||||
_g1h(g1h), _cm(cm), _cm_card_bm(cm_card_bm),
|
||||
_max_worker_id(max_worker_id),
|
||||
_active_workers(n_workers),
|
||||
_hrclaimer(_active_workers) {
|
||||
}
|
||||
|
||||
void work(uint worker_id) {
|
||||
AggregateCountDataHRClosure cl(_g1h, _cm_card_bm, _max_worker_id);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
_g1h->heap_region_par_iterate_chunked(&cl, worker_id,
|
||||
_active_workers,
|
||||
HeapRegion::AggregateCountClaimValue);
|
||||
_g1h->heap_region_par_iterate(&cl, worker_id, &_hrclaimer);
|
||||
} else {
|
||||
_g1h->heap_region_iterate(&cl);
|
||||
}
|
||||
@ -3323,15 +3283,9 @@ void ConcurrentMark::aggregate_count_data() {
|
||||
_max_worker_id, n_workers);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
assert(_g1h->check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
_g1h->set_par_threads(n_workers);
|
||||
_g1h->workers()->run_task(&g1_par_agg_task);
|
||||
_g1h->set_par_threads(0);
|
||||
|
||||
assert(_g1h->check_heap_region_claim_values(HeapRegion::AggregateCountClaimValue),
|
||||
"sanity check");
|
||||
_g1h->reset_heap_region_claim_values();
|
||||
} else {
|
||||
g1_par_agg_task.work(0);
|
||||
}
|
||||
|
@ -90,8 +90,8 @@ size_t G1CollectedHeap::_humongous_object_threshold_in_words = 0;
|
||||
|
||||
// Notes on implementation of parallelism in different tasks.
|
||||
//
|
||||
// G1ParVerifyTask uses heap_region_par_iterate_chunked() for parallelism.
|
||||
// The number of GC workers is passed to heap_region_par_iterate_chunked().
|
||||
// G1ParVerifyTask uses heap_region_par_iterate() for parallelism.
|
||||
// The number of GC workers is passed to heap_region_par_iterate().
|
||||
// It does use run_task() which sets _n_workers in the task.
|
||||
// G1ParTask executes g1_process_roots() ->
|
||||
// SharedHeap::process_roots() which calls eventually to
|
||||
@ -1215,17 +1215,15 @@ public:
|
||||
|
||||
class ParRebuildRSTask: public AbstractGangTask {
|
||||
G1CollectedHeap* _g1;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
ParRebuildRSTask(G1CollectedHeap* g1)
|
||||
: AbstractGangTask("ParRebuildRSTask"),
|
||||
_g1(g1)
|
||||
{ }
|
||||
ParRebuildRSTask(G1CollectedHeap* g1) :
|
||||
AbstractGangTask("ParRebuildRSTask"), _g1(g1), _hrclaimer(g1->workers()->active_workers()) {}
|
||||
|
||||
void work(uint worker_id) {
|
||||
RebuildRSOutOfRegionClosure rebuild_rs(_g1, worker_id);
|
||||
_g1->heap_region_par_iterate_chunked(&rebuild_rs, worker_id,
|
||||
_g1->workers()->active_workers(),
|
||||
HeapRegion::RebuildRSClaimValue);
|
||||
_g1->heap_region_par_iterate(&rebuild_rs, worker_id, &_hrclaimer);
|
||||
}
|
||||
};
|
||||
|
||||
@ -1455,8 +1453,6 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
|
||||
set_par_threads(n_workers);
|
||||
|
||||
ParRebuildRSTask rebuild_rs_task(this);
|
||||
assert(check_heap_region_claim_values(
|
||||
HeapRegion::InitialClaimValue), "sanity check");
|
||||
assert(UseDynamicNumberOfGCThreads ||
|
||||
workers()->active_workers() == workers()->total_workers(),
|
||||
"Unless dynamic should use total workers");
|
||||
@ -1466,9 +1462,6 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
|
||||
set_par_threads(workers()->active_workers());
|
||||
workers()->run_task(&rebuild_rs_task);
|
||||
set_par_threads(0);
|
||||
assert(check_heap_region_claim_values(
|
||||
HeapRegion::RebuildRSClaimValue), "sanity check");
|
||||
reset_heap_region_claim_values();
|
||||
} else {
|
||||
RebuildRSOutOfRegionClosure rebuild_rs(this);
|
||||
heap_region_iterate(&rebuild_rs);
|
||||
@ -2343,6 +2336,7 @@ bool G1CollectedHeap::should_do_concurrent_full_gc(GCCause::Cause cause) {
|
||||
case GCCause::_gc_locker: return GCLockerInvokesConcurrent;
|
||||
case GCCause::_java_lang_system_gc: return ExplicitGCInvokesConcurrent;
|
||||
case GCCause::_g1_humongous_allocation: return true;
|
||||
case GCCause::_update_allocation_context_stats_inc: return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
@ -2633,111 +2627,12 @@ void G1CollectedHeap::heap_region_iterate(HeapRegionClosure* cl) const {
|
||||
}
|
||||
|
||||
void
|
||||
G1CollectedHeap::heap_region_par_iterate_chunked(HeapRegionClosure* cl,
|
||||
uint worker_id,
|
||||
uint num_workers,
|
||||
jint claim_value) const {
|
||||
_hrm.par_iterate(cl, worker_id, num_workers, claim_value);
|
||||
G1CollectedHeap::heap_region_par_iterate(HeapRegionClosure* cl,
|
||||
uint worker_id,
|
||||
HeapRegionClaimer *hrclaimer) const {
|
||||
_hrm.par_iterate(cl, worker_id, hrclaimer);
|
||||
}
|
||||
|
||||
class ResetClaimValuesClosure: public HeapRegionClosure {
|
||||
public:
|
||||
bool doHeapRegion(HeapRegion* r) {
|
||||
r->set_claim_value(HeapRegion::InitialClaimValue);
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
void G1CollectedHeap::reset_heap_region_claim_values() {
|
||||
ResetClaimValuesClosure blk;
|
||||
heap_region_iterate(&blk);
|
||||
}
|
||||
|
||||
void G1CollectedHeap::reset_cset_heap_region_claim_values() {
|
||||
ResetClaimValuesClosure blk;
|
||||
collection_set_iterate(&blk);
|
||||
}
|
||||
|
||||
#ifdef ASSERT
|
||||
// This checks whether all regions in the heap have the correct claim
|
||||
// value. I also piggy-backed on this a check to ensure that the
|
||||
// humongous_start_region() information on "continues humongous"
|
||||
// regions is correct.
|
||||
|
||||
class CheckClaimValuesClosure : public HeapRegionClosure {
|
||||
private:
|
||||
jint _claim_value;
|
||||
uint _failures;
|
||||
HeapRegion* _sh_region;
|
||||
|
||||
public:
|
||||
CheckClaimValuesClosure(jint claim_value) :
|
||||
_claim_value(claim_value), _failures(0), _sh_region(NULL) { }
|
||||
bool doHeapRegion(HeapRegion* r) {
|
||||
if (r->claim_value() != _claim_value) {
|
||||
gclog_or_tty->print_cr("Region " HR_FORMAT ", "
|
||||
"claim value = %d, should be %d",
|
||||
HR_FORMAT_PARAMS(r),
|
||||
r->claim_value(), _claim_value);
|
||||
++_failures;
|
||||
}
|
||||
if (!r->is_humongous()) {
|
||||
_sh_region = NULL;
|
||||
} else if (r->is_starts_humongous()) {
|
||||
_sh_region = r;
|
||||
} else if (r->is_continues_humongous()) {
|
||||
if (r->humongous_start_region() != _sh_region) {
|
||||
gclog_or_tty->print_cr("Region " HR_FORMAT ", "
|
||||
"HS = "PTR_FORMAT", should be "PTR_FORMAT,
|
||||
HR_FORMAT_PARAMS(r),
|
||||
r->humongous_start_region(),
|
||||
_sh_region);
|
||||
++_failures;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
uint failures() { return _failures; }
|
||||
};
|
||||
|
||||
bool G1CollectedHeap::check_heap_region_claim_values(jint claim_value) {
|
||||
CheckClaimValuesClosure cl(claim_value);
|
||||
heap_region_iterate(&cl);
|
||||
return cl.failures() == 0;
|
||||
}
|
||||
|
||||
class CheckClaimValuesInCSetHRClosure: public HeapRegionClosure {
|
||||
private:
|
||||
jint _claim_value;
|
||||
uint _failures;
|
||||
|
||||
public:
|
||||
CheckClaimValuesInCSetHRClosure(jint claim_value) :
|
||||
_claim_value(claim_value), _failures(0) { }
|
||||
|
||||
uint failures() { return _failures; }
|
||||
|
||||
bool doHeapRegion(HeapRegion* hr) {
|
||||
assert(hr->in_collection_set(), "how?");
|
||||
assert(!hr->is_humongous(), "H-region in CSet");
|
||||
if (hr->claim_value() != _claim_value) {
|
||||
gclog_or_tty->print_cr("CSet Region " HR_FORMAT ", "
|
||||
"claim value = %d, should be %d",
|
||||
HR_FORMAT_PARAMS(hr),
|
||||
hr->claim_value(), _claim_value);
|
||||
_failures += 1;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
bool G1CollectedHeap::check_cset_heap_region_claim_values(jint claim_value) {
|
||||
CheckClaimValuesInCSetHRClosure cl(claim_value);
|
||||
collection_set_iterate(&cl);
|
||||
return cl.failures() == 0;
|
||||
}
|
||||
#endif // ASSERT
|
||||
|
||||
// Clear the cached CSet starting regions and (more importantly)
|
||||
// the time stamps. Called when we reset the GC time stamp.
|
||||
void G1CollectedHeap::clear_cset_start_regions() {
|
||||
@ -3251,19 +3146,21 @@ public:
|
||||
|
||||
class G1ParVerifyTask: public AbstractGangTask {
|
||||
private:
|
||||
G1CollectedHeap* _g1h;
|
||||
VerifyOption _vo;
|
||||
bool _failures;
|
||||
G1CollectedHeap* _g1h;
|
||||
VerifyOption _vo;
|
||||
bool _failures;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
// _vo == UsePrevMarking -> use "prev" marking information,
|
||||
// _vo == UseNextMarking -> use "next" marking information,
|
||||
// _vo == UseMarkWord -> use mark word from object header.
|
||||
G1ParVerifyTask(G1CollectedHeap* g1h, VerifyOption vo) :
|
||||
AbstractGangTask("Parallel verify task"),
|
||||
_g1h(g1h),
|
||||
_vo(vo),
|
||||
_failures(false) { }
|
||||
AbstractGangTask("Parallel verify task"),
|
||||
_g1h(g1h),
|
||||
_vo(vo),
|
||||
_failures(false),
|
||||
_hrclaimer(g1h->workers()->active_workers()) {}
|
||||
|
||||
bool failures() {
|
||||
return _failures;
|
||||
@ -3272,9 +3169,7 @@ public:
|
||||
void work(uint worker_id) {
|
||||
HandleMark hm;
|
||||
VerifyRegionClosure blk(true, _vo);
|
||||
_g1h->heap_region_par_iterate_chunked(&blk, worker_id,
|
||||
_g1h->workers()->active_workers(),
|
||||
HeapRegion::ParVerifyClaimValue);
|
||||
_g1h->heap_region_par_iterate(&blk, worker_id, &_hrclaimer);
|
||||
if (blk.failures()) {
|
||||
_failures = true;
|
||||
}
|
||||
@ -3316,8 +3211,6 @@ void G1CollectedHeap::verify(bool silent, VerifyOption vo) {
|
||||
|
||||
if (!silent) { gclog_or_tty->print("HeapRegions "); }
|
||||
if (GCParallelVerificationEnabled && ParallelGCThreads > 1) {
|
||||
assert(check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
|
||||
G1ParVerifyTask task(this, vo);
|
||||
assert(UseDynamicNumberOfGCThreads ||
|
||||
@ -3331,15 +3224,6 @@ void G1CollectedHeap::verify(bool silent, VerifyOption vo) {
|
||||
failures = true;
|
||||
}
|
||||
|
||||
// Checks that the expected amount of parallel work was done.
|
||||
// The implication is that n_workers is > 0.
|
||||
assert(check_heap_region_claim_values(HeapRegion::ParVerifyClaimValue),
|
||||
"sanity check");
|
||||
|
||||
reset_heap_region_claim_values();
|
||||
|
||||
assert(check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
VerifyRegionClosure blk(false, vo);
|
||||
heap_region_iterate(&blk);
|
||||
@ -3926,8 +3810,6 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
|
||||
}
|
||||
|
||||
assert(check_young_list_well_formed(), "young list should be well formed");
|
||||
assert(check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
|
||||
// Don't dynamically change the number of GC threads this early. A value of
|
||||
// 0 is used to indicate serial work. When parallel work is done,
|
||||
@ -4288,26 +4170,12 @@ void G1CollectedHeap::finalize_for_evac_failure() {
|
||||
}
|
||||
|
||||
void G1CollectedHeap::remove_self_forwarding_pointers() {
|
||||
assert(check_cset_heap_region_claim_values(HeapRegion::InitialClaimValue), "sanity");
|
||||
|
||||
double remove_self_forwards_start = os::elapsedTime();
|
||||
|
||||
set_par_threads();
|
||||
G1ParRemoveSelfForwardPtrsTask rsfp_task(this);
|
||||
|
||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||
set_par_threads();
|
||||
workers()->run_task(&rsfp_task);
|
||||
set_par_threads(0);
|
||||
} else {
|
||||
rsfp_task.work(0);
|
||||
}
|
||||
|
||||
assert(check_cset_heap_region_claim_values(HeapRegion::ParEvacFailureClaimValue), "sanity");
|
||||
|
||||
// Reset the claim values in the regions in the collection set.
|
||||
reset_cset_heap_region_claim_values();
|
||||
|
||||
assert(check_cset_heap_region_claim_values(HeapRegion::InitialClaimValue), "sanity");
|
||||
workers()->run_task(&rsfp_task);
|
||||
set_par_threads(0);
|
||||
|
||||
// Now restore saved marks, if any.
|
||||
assert(_objs_with_preserved_marks.size() ==
|
||||
@ -5948,11 +5816,6 @@ void G1CollectedHeap::evacuate_collection_set(EvacuationInfo& evacuation_info) {
|
||||
|
||||
purge_code_root_memory();
|
||||
|
||||
if (g1_policy()->during_initial_mark_pause()) {
|
||||
// Reset the claim values set during marking the strong code roots
|
||||
reset_heap_region_claim_values();
|
||||
}
|
||||
|
||||
finalize_for_evac_failure();
|
||||
|
||||
if (evacuation_failed()) {
|
||||
|
@ -211,6 +211,7 @@ class G1CollectedHeap : public SharedHeap {
|
||||
friend class G1FreeHumongousRegionClosure;
|
||||
// Other related classes.
|
||||
friend class G1MarkSweep;
|
||||
friend class HeapRegionClaimer;
|
||||
|
||||
private:
|
||||
// The one and only G1CollectedHeap, so static functions can find it.
|
||||
@ -1377,38 +1378,15 @@ public:
|
||||
|
||||
inline HeapWord* bottom_addr_for_region(uint index) const;
|
||||
|
||||
// Divide the heap region sequence into "chunks" of some size (the number
|
||||
// of regions divided by the number of parallel threads times some
|
||||
// overpartition factor, currently 4). Assumes that this will be called
|
||||
// in parallel by ParallelGCThreads worker threads with distinct worker
|
||||
// ids in the range [0..max(ParallelGCThreads-1, 1)], that all parallel
|
||||
// calls will use the same "claim_value", and that that claim value is
|
||||
// different from the claim_value of any heap region before the start of
|
||||
// the iteration. Applies "blk->doHeapRegion" to each of the regions, by
|
||||
// attempting to claim the first region in each chunk, and, if
|
||||
// successful, applying the closure to each region in the chunk (and
|
||||
// setting the claim value of the second and subsequent regions of the
|
||||
// chunk.) For now requires that "doHeapRegion" always returns "false",
|
||||
// i.e., that a closure never attempt to abort a traversal.
|
||||
void heap_region_par_iterate_chunked(HeapRegionClosure* cl,
|
||||
uint worker_id,
|
||||
uint num_workers,
|
||||
jint claim_value) const;
|
||||
|
||||
// It resets all the region claim values to the default.
|
||||
void reset_heap_region_claim_values();
|
||||
|
||||
// Resets the claim values of regions in the current
|
||||
// collection set to the default.
|
||||
void reset_cset_heap_region_claim_values();
|
||||
|
||||
#ifdef ASSERT
|
||||
bool check_heap_region_claim_values(jint claim_value);
|
||||
|
||||
// Same as the routine above but only checks regions in the
|
||||
// current collection set.
|
||||
bool check_cset_heap_region_claim_values(jint claim_value);
|
||||
#endif // ASSERT
|
||||
// Iterate over the heap regions in parallel. Assumes that this will be called
|
||||
// in parallel by ParallelGCThreads worker threads with distinct worker ids
|
||||
// in the range [0..max(ParallelGCThreads-1, 1)]. Applies "blk->doHeapRegion"
|
||||
// to each of the regions, by attempting to claim the region using the
|
||||
// HeapRegionClaimer and, if successful, applying the closure to the claimed
|
||||
// region.
|
||||
void heap_region_par_iterate(HeapRegionClosure* cl,
|
||||
uint worker_id,
|
||||
HeapRegionClaimer* hrclaimer) const;
|
||||
|
||||
// Clear the cached cset start regions and (more importantly)
|
||||
// the time stamps. Called when we reset the GC time stamp.
|
||||
|
@ -1598,19 +1598,17 @@ class ParKnownGarbageTask: public AbstractGangTask {
|
||||
CollectionSetChooser* _hrSorted;
|
||||
uint _chunk_size;
|
||||
G1CollectedHeap* _g1;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
ParKnownGarbageTask(CollectionSetChooser* hrSorted, uint chunk_size) :
|
||||
AbstractGangTask("ParKnownGarbageTask"),
|
||||
_hrSorted(hrSorted), _chunk_size(chunk_size),
|
||||
_g1(G1CollectedHeap::heap()) { }
|
||||
ParKnownGarbageTask(CollectionSetChooser* hrSorted, uint chunk_size, uint n_workers) :
|
||||
AbstractGangTask("ParKnownGarbageTask"),
|
||||
_hrSorted(hrSorted), _chunk_size(chunk_size),
|
||||
_g1(G1CollectedHeap::heap()), _hrclaimer(n_workers) {}
|
||||
|
||||
void work(uint worker_id) {
|
||||
ParKnownGarbageHRClosure parKnownGarbageCl(_hrSorted, _chunk_size);
|
||||
|
||||
// Back to zero for the claim value.
|
||||
_g1->heap_region_par_iterate_chunked(&parKnownGarbageCl, worker_id,
|
||||
_g1->workers()->active_workers(),
|
||||
HeapRegion::InitialClaimValue);
|
||||
_g1->heap_region_par_iterate(&parKnownGarbageCl, worker_id, &_hrclaimer);
|
||||
}
|
||||
};
|
||||
|
||||
@ -1641,12 +1639,8 @@ G1CollectorPolicy::record_concurrent_mark_cleanup_end(int no_of_gc_threads) {
|
||||
}
|
||||
_collectionSetChooser->prepare_for_par_region_addition(_g1->num_regions(),
|
||||
WorkUnit);
|
||||
ParKnownGarbageTask parKnownGarbageTask(_collectionSetChooser,
|
||||
(int) WorkUnit);
|
||||
ParKnownGarbageTask parKnownGarbageTask(_collectionSetChooser, WorkUnit, (uint) no_of_gc_threads);
|
||||
_g1->workers()->run_task(&parKnownGarbageTask);
|
||||
|
||||
assert(_g1->check_heap_region_claim_values(HeapRegion::InitialClaimValue),
|
||||
"sanity check");
|
||||
} else {
|
||||
KnownGarbageClosure knownGarbagecl(_collectionSetChooser);
|
||||
_g1->heap_region_iterate(&knownGarbagecl);
|
||||
|
@ -177,16 +177,18 @@ class RemoveSelfForwardPtrHRClosure: public HeapRegionClosure {
|
||||
G1CollectedHeap* _g1h;
|
||||
ConcurrentMark* _cm;
|
||||
uint _worker_id;
|
||||
HeapRegionClaimer* _hrclaimer;
|
||||
|
||||
DirtyCardQueue _dcq;
|
||||
UpdateRSetDeferred _update_rset_cl;
|
||||
|
||||
public:
|
||||
RemoveSelfForwardPtrHRClosure(G1CollectedHeap* g1h,
|
||||
uint worker_id) :
|
||||
_g1h(g1h), _dcq(&g1h->dirty_card_queue_set()), _update_rset_cl(g1h, &_dcq),
|
||||
_worker_id(worker_id), _cm(_g1h->concurrent_mark()) {
|
||||
}
|
||||
uint worker_id,
|
||||
HeapRegionClaimer* hrclaimer) :
|
||||
_g1h(g1h), _dcq(&g1h->dirty_card_queue_set()), _update_rset_cl(g1h, &_dcq),
|
||||
_worker_id(worker_id), _cm(_g1h->concurrent_mark()), _hrclaimer(hrclaimer) {
|
||||
}
|
||||
|
||||
bool doHeapRegion(HeapRegion *hr) {
|
||||
bool during_initial_mark = _g1h->g1_policy()->during_initial_mark_pause();
|
||||
@ -195,7 +197,7 @@ public:
|
||||
assert(!hr->is_humongous(), "sanity");
|
||||
assert(hr->in_collection_set(), "bad CS");
|
||||
|
||||
if (hr->claimHeapRegion(HeapRegion::ParEvacFailureClaimValue)) {
|
||||
if (_hrclaimer->claim_region(hr->hrm_index())) {
|
||||
if (hr->evacuation_failed()) {
|
||||
RemoveSelfForwardPtrObjClosure rspc(_g1h, _cm, hr, &_update_rset_cl,
|
||||
during_initial_mark,
|
||||
@ -233,14 +235,15 @@ public:
|
||||
class G1ParRemoveSelfForwardPtrsTask: public AbstractGangTask {
|
||||
protected:
|
||||
G1CollectedHeap* _g1h;
|
||||
HeapRegionClaimer _hrclaimer;
|
||||
|
||||
public:
|
||||
G1ParRemoveSelfForwardPtrsTask(G1CollectedHeap* g1h) :
|
||||
AbstractGangTask("G1 Remove Self-forwarding Pointers"),
|
||||
_g1h(g1h) { }
|
||||
AbstractGangTask("G1 Remove Self-forwarding Pointers"), _g1h(g1h),
|
||||
_hrclaimer(g1h->workers()->active_workers()) {}
|
||||
|
||||
void work(uint worker_id) {
|
||||
RemoveSelfForwardPtrHRClosure rsfp_cl(_g1h, worker_id);
|
||||
RemoveSelfForwardPtrHRClosure rsfp_cl(_g1h, worker_id, &_hrclaimer);
|
||||
|
||||
HeapRegion* hr = _g1h->start_cset_region_for_worker(worker_id);
|
||||
_g1h->collection_set_iterate_from(hr, &rsfp_cl);
|
||||
|
@ -425,13 +425,9 @@ void G1RemSet::scrub(BitMap* region_bm, BitMap* card_bm) {
|
||||
_g1->heap_region_iterate(&scrub_cl);
|
||||
}
|
||||
|
||||
void G1RemSet::scrub_par(BitMap* region_bm, BitMap* card_bm,
|
||||
uint worker_num, int claim_val) {
|
||||
void G1RemSet::scrub_par(BitMap* region_bm, BitMap* card_bm, uint worker_num, HeapRegionClaimer *hrclaimer) {
|
||||
ScrubRSClosure scrub_cl(region_bm, card_bm);
|
||||
_g1->heap_region_par_iterate_chunked(&scrub_cl,
|
||||
worker_num,
|
||||
n_workers(),
|
||||
claim_val);
|
||||
_g1->heap_region_par_iterate(&scrub_cl, worker_num, hrclaimer);
|
||||
}
|
||||
|
||||
G1TriggerClosure::G1TriggerClosure() :
|
||||
|
@ -128,10 +128,10 @@ public:
|
||||
void scrub(BitMap* region_bm, BitMap* card_bm);
|
||||
|
||||
// Like the above, but assumes is called in parallel: "worker_num" is the
|
||||
// parallel thread id of the current thread, and "claim_val" is the
|
||||
// value that should be used to claim heap regions.
|
||||
// parallel thread id of the current thread, and "hrclaimer" is the shared
|
||||
// HeapRegionClaimer that should be used to claim heap regions.
|
||||
void scrub_par(BitMap* region_bm, BitMap* card_bm,
|
||||
uint worker_num, int claim_val);
|
||||
uint worker_num, HeapRegionClaimer* hrclaimer);
|
||||
|
||||
// Refine the card corresponding to "card_ptr".
|
||||
// If check_for_refs_into_cset is true, a true result is returned
|
||||
|
@ -217,7 +217,6 @@ void HeapRegion::hr_clear(bool par, bool clear_space, bool locked) {
|
||||
} else {
|
||||
hrrs->clear();
|
||||
}
|
||||
_claimed = InitialClaimValue;
|
||||
}
|
||||
zero_marked_bytes();
|
||||
|
||||
@ -294,17 +293,6 @@ void HeapRegion::clear_humongous() {
|
||||
_humongous_start_region = NULL;
|
||||
}
|
||||
|
||||
bool HeapRegion::claimHeapRegion(jint claimValue) {
|
||||
jint current = _claimed;
|
||||
if (current != claimValue) {
|
||||
jint res = Atomic::cmpxchg(claimValue, &_claimed, current);
|
||||
if (res == current) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
HeapRegion::HeapRegion(uint hrm_index,
|
||||
G1BlockOffsetSharedArray* sharedOffsetArray,
|
||||
MemRegion mr) :
|
||||
@ -314,7 +302,7 @@ HeapRegion::HeapRegion(uint hrm_index,
|
||||
_humongous_start_region(NULL),
|
||||
_in_collection_set(false),
|
||||
_next_in_special_set(NULL),
|
||||
_claimed(InitialClaimValue), _evacuation_failed(false),
|
||||
_evacuation_failed(false),
|
||||
_prev_marked_bytes(0), _next_marked_bytes(0), _gc_efficiency(0.0),
|
||||
_next_young_region(NULL),
|
||||
_next_dirty_cards_region(NULL), _next(NULL), _prev(NULL),
|
||||
|
@ -254,9 +254,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
|
||||
HeapRegionSetBase* _containing_set;
|
||||
#endif // ASSERT
|
||||
|
||||
// For parallel heapRegion traversal.
|
||||
jint _claimed;
|
||||
|
||||
// We use concurrent marking to determine the amount of live data
|
||||
// in each heap region.
|
||||
size_t _prev_marked_bytes; // Bytes known to be live via last completed marking.
|
||||
@ -336,19 +333,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
|
||||
// up once during initialization time.
|
||||
static void setup_heap_region_size(size_t initial_heap_size, size_t max_heap_size);
|
||||
|
||||
enum ClaimValues {
|
||||
InitialClaimValue = 0,
|
||||
FinalCountClaimValue = 1,
|
||||
NoteEndClaimValue = 2,
|
||||
ScrubRemSetClaimValue = 3,
|
||||
ParVerifyClaimValue = 4,
|
||||
RebuildRSClaimValue = 5,
|
||||
ParEvacFailureClaimValue = 6,
|
||||
AggregateCountClaimValue = 7,
|
||||
VerifyCountClaimValue = 8,
|
||||
ParMarkRootClaimValue = 9
|
||||
};
|
||||
|
||||
// All allocated blocks are occupied by objects in a HeapRegion
|
||||
bool block_is_obj(const HeapWord* p) const;
|
||||
|
||||
@ -691,12 +675,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
|
||||
return (HeapWord *) obj >= next_top_at_mark_start();
|
||||
}
|
||||
|
||||
// For parallel heapRegion traversal.
|
||||
bool claimHeapRegion(int claimValue);
|
||||
jint claim_value() { return _claimed; }
|
||||
// Use this carefully: only when you're sure no one is claiming...
|
||||
void set_claim_value(int claimValue) { _claimed = claimValue; }
|
||||
|
||||
// Returns the "evacuation_failed" property of the region.
|
||||
bool evacuation_failed() { return _evacuation_failed; }
|
||||
|
||||
|
@ -260,20 +260,17 @@ uint HeapRegionManager::find_unavailable_from_idx(uint start_idx, uint* res_idx)
|
||||
return num_regions;
|
||||
}
|
||||
|
||||
uint HeapRegionManager::start_region_for_worker(uint worker_i, uint num_workers, uint num_regions) const {
|
||||
return num_regions * worker_i / num_workers;
|
||||
}
|
||||
|
||||
void HeapRegionManager::par_iterate(HeapRegionClosure* blk, uint worker_id, uint num_workers, jint claim_value) const {
|
||||
const uint start_index = start_region_for_worker(worker_id, num_workers, _allocated_heapregions_length);
|
||||
void HeapRegionManager::par_iterate(HeapRegionClosure* blk, uint worker_id, HeapRegionClaimer* hrclaimer) const {
|
||||
const uint start_index = hrclaimer->start_region_for_worker(worker_id);
|
||||
|
||||
// Every worker will actually look at all regions, skipping over regions that
|
||||
// are currently not committed.
|
||||
// This also (potentially) iterates over regions newly allocated during GC. This
|
||||
// is no problem except for some extra work.
|
||||
for (uint count = 0; count < _allocated_heapregions_length; count++) {
|
||||
const uint index = (start_index + count) % _allocated_heapregions_length;
|
||||
assert(0 <= index && index < _allocated_heapregions_length, "sanity");
|
||||
const uint n_regions = hrclaimer->n_regions();
|
||||
for (uint count = 0; count < n_regions; count++) {
|
||||
const uint index = (start_index + count) % n_regions;
|
||||
assert(0 <= index && index < n_regions, "sanity");
|
||||
// Skip over unavailable regions
|
||||
if (!is_available(index)) {
|
||||
continue;
|
||||
@ -282,11 +279,11 @@ void HeapRegionManager::par_iterate(HeapRegionClosure* blk, uint worker_id, uint
|
||||
// We'll ignore "continues humongous" regions (we'll process them
|
||||
// when we come across their corresponding "start humongous"
|
||||
// region) and regions already claimed.
|
||||
if (r->claim_value() == claim_value || r->is_continues_humongous()) {
|
||||
if (hrclaimer->is_region_claimed(index) || r->is_continues_humongous()) {
|
||||
continue;
|
||||
}
|
||||
// OK, try to claim it
|
||||
if (!r->claimHeapRegion(claim_value)) {
|
||||
if (!hrclaimer->claim_region(index)) {
|
||||
continue;
|
||||
}
|
||||
// Success!
|
||||
@ -306,13 +303,11 @@ void HeapRegionManager::par_iterate(HeapRegionClosure* blk, uint worker_id, uint
|
||||
assert(chr->humongous_start_region() == r,
|
||||
err_msg("Must work on humongous continuation of the original start region "
|
||||
PTR_FORMAT ", but is " PTR_FORMAT, p2i(r), p2i(chr)));
|
||||
assert(chr->claim_value() != claim_value,
|
||||
assert(!hrclaimer->is_region_claimed(ch_index),
|
||||
"Must not have been claimed yet because claiming of humongous continuation first claims the start region");
|
||||
|
||||
bool claim_result = chr->claimHeapRegion(claim_value);
|
||||
// We should always be able to claim it; no one else should
|
||||
// be trying to claim this region.
|
||||
guarantee(claim_result, "We should always be able to claim the is_continues_humongous part of the humongous object");
|
||||
// There's no need to actually claim the continues humongous region, but we can do it in an assert as an extra precaution.
|
||||
assert(hrclaimer->claim_region(ch_index), "We should always be able to claim the continuesHumongous part of the humongous object");
|
||||
|
||||
bool res2 = blk->doHeapRegion(chr);
|
||||
if (res2) {
|
||||
@ -445,3 +440,31 @@ void HeapRegionManager::verify_optional() {
|
||||
}
|
||||
#endif // PRODUCT
|
||||
|
||||
HeapRegionClaimer::HeapRegionClaimer(uint n_workers) :
|
||||
_n_workers(n_workers), _n_regions(G1CollectedHeap::heap()->_hrm._allocated_heapregions_length), _claims(NULL) {
|
||||
assert(n_workers > 0, "Need at least one worker.");
|
||||
_claims = NEW_C_HEAP_ARRAY(uint, _n_regions, mtGC);
|
||||
memset(_claims, Unclaimed, sizeof(*_claims) * _n_regions);
|
||||
}
|
||||
|
||||
HeapRegionClaimer::~HeapRegionClaimer() {
|
||||
if (_claims != NULL) {
|
||||
FREE_C_HEAP_ARRAY(uint, _claims, mtGC);
|
||||
}
|
||||
}
|
||||
|
||||
uint HeapRegionClaimer::start_region_for_worker(uint worker_id) const {
|
||||
assert(worker_id < _n_workers, "Invalid worker_id.");
|
||||
return _n_regions * worker_id / _n_workers;
|
||||
}
|
||||
|
||||
bool HeapRegionClaimer::is_region_claimed(uint region_index) const {
|
||||
assert(region_index < _n_regions, "Invalid index.");
|
||||
return _claims[region_index] == Claimed;
|
||||
}
|
||||
|
||||
bool HeapRegionClaimer::claim_region(uint region_index) {
|
||||
assert(region_index < _n_regions, "Invalid index.");
|
||||
uint old_val = Atomic::cmpxchg(Claimed, &_claims[region_index], Unclaimed);
|
||||
return old_val == Unclaimed;
|
||||
}
|
||||
|
@ -31,6 +31,7 @@
|
||||
|
||||
class HeapRegion;
|
||||
class HeapRegionClosure;
|
||||
class HeapRegionClaimer;
|
||||
class FreeRegionList;
|
||||
|
||||
class G1HeapRegionTable : public G1BiasedMappedArray<HeapRegion*> {
|
||||
@ -66,6 +67,7 @@ class G1HeapRegionTable : public G1BiasedMappedArray<HeapRegion*> {
|
||||
|
||||
class HeapRegionManager: public CHeapObj<mtGC> {
|
||||
friend class VMStructs;
|
||||
friend class HeapRegionClaimer;
|
||||
|
||||
G1HeapRegionTable _regions;
|
||||
|
||||
@ -99,9 +101,6 @@ class HeapRegionManager: public CHeapObj<mtGC> {
|
||||
|
||||
// Notify other data structures about change in the heap layout.
|
||||
void update_committed_space(HeapWord* old_end, HeapWord* new_end);
|
||||
// Calculate the starting region for each worker during parallel iteration so
|
||||
// that they do not all start from the same region.
|
||||
uint start_region_for_worker(uint worker_i, uint num_workers, uint num_regions) const;
|
||||
|
||||
// Find a contiguous set of empty or uncommitted regions of length num and return
|
||||
// the index of the first region or G1_NO_HRM_INDEX if the search was unsuccessful.
|
||||
@ -223,7 +222,7 @@ public:
|
||||
// terminating the iteration early if doHeapRegion() returns true.
|
||||
void iterate(HeapRegionClosure* blk) const;
|
||||
|
||||
void par_iterate(HeapRegionClosure* blk, uint worker_id, uint no_of_par_workers, jint claim_value) const;
|
||||
void par_iterate(HeapRegionClosure* blk, uint worker_id, HeapRegionClaimer* hrclaimer) const;
|
||||
|
||||
// Uncommit up to num_regions_to_remove regions that are completely free.
|
||||
// Return the actual number of uncommitted regions.
|
||||
@ -235,5 +234,33 @@ public:
|
||||
void verify_optional() PRODUCT_RETURN;
|
||||
};
|
||||
|
||||
// The HeapRegionClaimer is used during parallel iteration over heap regions,
|
||||
// allowing workers to claim heap regions, gaining exclusive rights to these regions.
|
||||
class HeapRegionClaimer : public StackObj {
|
||||
uint _n_workers;
|
||||
uint _n_regions;
|
||||
uint* _claims;
|
||||
|
||||
static const uint Unclaimed = 0;
|
||||
static const uint Claimed = 1;
|
||||
|
||||
public:
|
||||
HeapRegionClaimer(uint n_workers);
|
||||
~HeapRegionClaimer();
|
||||
|
||||
inline uint n_regions() const {
|
||||
return _n_regions;
|
||||
}
|
||||
|
||||
// Calculate the starting region for given worker so
|
||||
// that they do not all start from the same region.
|
||||
uint start_region_for_worker(uint worker_id) const;
|
||||
|
||||
// Check if region has been claimed with this HRClaimer.
|
||||
bool is_region_claimed(uint region_index) const;
|
||||
|
||||
// Claim the given region, returns true if successfully claimed.
|
||||
bool claim_region(uint region_index);
|
||||
};
|
||||
#endif // SHARE_VM_GC_IMPLEMENTATION_G1_HEAPREGIONMANAGER_HPP
|
||||
|
||||
|
@ -95,8 +95,9 @@ void VM_G1IncCollectionPause::doit() {
|
||||
assert(!_should_initiate_conc_mark ||
|
||||
((_gc_cause == GCCause::_gc_locker && GCLockerInvokesConcurrent) ||
|
||||
(_gc_cause == GCCause::_java_lang_system_gc && ExplicitGCInvokesConcurrent) ||
|
||||
_gc_cause == GCCause::_g1_humongous_allocation),
|
||||
"only a GC locker, a System.gc() or a hum allocation induced GC should start a cycle");
|
||||
_gc_cause == GCCause::_g1_humongous_allocation ||
|
||||
_gc_cause == GCCause::_update_allocation_context_stats_inc),
|
||||
"only a GC locker, a System.gc(), stats update or a hum allocation induced GC should start a cycle");
|
||||
|
||||
if (_word_size > 0) {
|
||||
// An allocation has been requested. So, try to do that first.
|
||||
|
@ -54,7 +54,8 @@ const char* GCCause::to_string(GCCause::Cause cause) {
|
||||
case _wb_young_gc:
|
||||
return "WhiteBox Initiated Young GC";
|
||||
|
||||
case _update_allocation_context_stats:
|
||||
case _update_allocation_context_stats_inc:
|
||||
case _update_allocation_context_stats_full:
|
||||
return "Update Allocation Context Stats";
|
||||
|
||||
case _no_gc:
|
||||
|
@ -47,7 +47,8 @@ class GCCause : public AllStatic {
|
||||
_heap_inspection,
|
||||
_heap_dump,
|
||||
_wb_young_gc,
|
||||
_update_allocation_context_stats,
|
||||
_update_allocation_context_stats_inc,
|
||||
_update_allocation_context_stats_full,
|
||||
|
||||
/* implementation independent, but reserved for GC use */
|
||||
_no_gc,
|
||||
|
@ -246,6 +246,12 @@ void LinkResolver::lookup_method_in_klasses(methodHandle& result, KlassHandle kl
|
||||
// Ignore overpasses so statics can be found during resolution
|
||||
Method* result_oop = klass->uncached_lookup_method(name, signature, Klass::skip_overpass);
|
||||
|
||||
if (klass->oop_is_array()) {
|
||||
// Only consider klass and super klass for arrays
|
||||
result = methodHandle(THREAD, result_oop);
|
||||
return;
|
||||
}
|
||||
|
||||
// JDK 8, JVMS 5.4.3.4: Interface method resolution should
|
||||
// ignore static and non-public methods of java.lang.Object,
|
||||
// like clone, finalize, registerNatives.
|
||||
@ -290,6 +296,11 @@ void LinkResolver::lookup_instance_method_in_klasses(methodHandle& result, Klass
|
||||
result = methodHandle(THREAD, super_klass->uncached_lookup_method(name, signature, Klass::normal));
|
||||
}
|
||||
|
||||
if (klass->oop_is_array()) {
|
||||
// Only consider klass and super klass for arrays
|
||||
return;
|
||||
}
|
||||
|
||||
if (result.is_null()) {
|
||||
Array<Method*>* default_methods = InstanceKlass::cast(klass())->default_methods();
|
||||
if (default_methods != NULL) {
|
||||
@ -545,7 +556,7 @@ void LinkResolver::resolve_method(methodHandle& resolved_method, KlassHandle res
|
||||
// 2. lookup method in resolved klass and its super klasses
|
||||
lookup_method_in_klasses(resolved_method, resolved_klass, method_name, method_signature, true, false, CHECK);
|
||||
|
||||
if (resolved_method.is_null()) { // not found in the class hierarchy
|
||||
if (resolved_method.is_null() && !resolved_klass->oop_is_array()) { // not found in the class hierarchy
|
||||
// 3. lookup method in all the interfaces implemented by the resolved klass
|
||||
lookup_method_in_interfaces(resolved_method, resolved_klass, method_name, method_signature, CHECK);
|
||||
|
||||
@ -558,16 +569,16 @@ void LinkResolver::resolve_method(methodHandle& resolved_method, KlassHandle res
|
||||
CLEAR_PENDING_EXCEPTION;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (resolved_method.is_null()) {
|
||||
// 4. method lookup failed
|
||||
ResourceMark rm(THREAD);
|
||||
THROW_MSG_CAUSE(vmSymbols::java_lang_NoSuchMethodError(),
|
||||
Method::name_and_sig_as_C_string(resolved_klass(),
|
||||
method_name,
|
||||
method_signature),
|
||||
nested_exception);
|
||||
}
|
||||
if (resolved_method.is_null()) {
|
||||
// 4. method lookup failed
|
||||
ResourceMark rm(THREAD);
|
||||
THROW_MSG_CAUSE(vmSymbols::java_lang_NoSuchMethodError(),
|
||||
Method::name_and_sig_as_C_string(resolved_klass(),
|
||||
method_name,
|
||||
method_signature),
|
||||
nested_exception);
|
||||
}
|
||||
|
||||
// 5. access checks, access checking may be turned off when calling from within the VM.
|
||||
@ -633,17 +644,18 @@ void LinkResolver::resolve_interface_method(methodHandle& resolved_method,
|
||||
// JDK8: also look for static methods
|
||||
lookup_method_in_klasses(resolved_method, resolved_klass, method_name, method_signature, false, true, CHECK);
|
||||
|
||||
if (resolved_method.is_null()) {
|
||||
if (resolved_method.is_null() && !resolved_klass->oop_is_array()) {
|
||||
// lookup method in all the super-interfaces
|
||||
lookup_method_in_interfaces(resolved_method, resolved_klass, method_name, method_signature, CHECK);
|
||||
if (resolved_method.is_null()) {
|
||||
// no method found
|
||||
ResourceMark rm(THREAD);
|
||||
THROW_MSG(vmSymbols::java_lang_NoSuchMethodError(),
|
||||
Method::name_and_sig_as_C_string(resolved_klass(),
|
||||
method_name,
|
||||
method_signature));
|
||||
}
|
||||
}
|
||||
|
||||
if (resolved_method.is_null()) {
|
||||
// no method found
|
||||
ResourceMark rm(THREAD);
|
||||
THROW_MSG(vmSymbols::java_lang_NoSuchMethodError(),
|
||||
Method::name_and_sig_as_C_string(resolved_klass(),
|
||||
method_name,
|
||||
method_signature));
|
||||
}
|
||||
|
||||
if (check_access) {
|
||||
@ -775,7 +787,7 @@ void LinkResolver::resolve_field(fieldDescriptor& fd, KlassHandle resolved_klass
|
||||
}
|
||||
|
||||
// Resolve instance field
|
||||
KlassHandle sel_klass(THREAD, InstanceKlass::cast(resolved_klass())->find_field(field, sig, &fd));
|
||||
KlassHandle sel_klass(THREAD, resolved_klass->find_field(field, sig, &fd));
|
||||
// check if field exists; i.e., if a klass containing the field def has been selected
|
||||
if (sel_klass.is_null()) {
|
||||
ResourceMark rm(THREAD);
|
||||
|
@ -331,6 +331,14 @@ bool FileMapInfo::init_from_file(int fd) {
|
||||
return false;
|
||||
}
|
||||
|
||||
size_t len = lseek(fd, 0, SEEK_END);
|
||||
struct FileMapInfo::FileMapHeader::space_info* si =
|
||||
&_header->_space[MetaspaceShared::mc];
|
||||
if (si->_file_offset >= len || len - si->_file_offset < si->_used) {
|
||||
fail_continue("The shared archive file has been truncated.");
|
||||
return false;
|
||||
}
|
||||
|
||||
_file_offset += (long)n;
|
||||
return true;
|
||||
}
|
||||
@ -431,6 +439,7 @@ void FileMapInfo::write_region(int region, char* base, size_t size,
|
||||
si->_capacity = capacity;
|
||||
si->_read_only = read_only;
|
||||
si->_allow_exec = allow_exec;
|
||||
si->_crc = ClassLoader::crc32(0, base, (jint)size);
|
||||
write_bytes_aligned(base, (int)size);
|
||||
}
|
||||
|
||||
@ -455,14 +464,15 @@ void FileMapInfo::write_bytes(const void* buffer, int nbytes) {
|
||||
// Align file position to an allocation unit boundary.
|
||||
|
||||
void FileMapInfo::align_file_position() {
|
||||
long new_file_offset = align_size_up(_file_offset, os::vm_allocation_granularity());
|
||||
size_t new_file_offset = align_size_up(_file_offset,
|
||||
os::vm_allocation_granularity());
|
||||
if (new_file_offset != _file_offset) {
|
||||
_file_offset = new_file_offset;
|
||||
if (_file_open) {
|
||||
// Seek one byte back from the target and write a byte to insure
|
||||
// that the written file is the correct length.
|
||||
_file_offset -= 1;
|
||||
if (lseek(_fd, _file_offset, SEEK_SET) < 0) {
|
||||
if (lseek(_fd, (long)_file_offset, SEEK_SET) < 0) {
|
||||
fail_stop("Unable to seek.");
|
||||
}
|
||||
char zero = 0;
|
||||
@ -569,6 +579,19 @@ char* FileMapInfo::map_region(int i) {
|
||||
return base;
|
||||
}
|
||||
|
||||
bool FileMapInfo::verify_region_checksum(int i) {
|
||||
if (!VerifySharedSpaces) {
|
||||
return true;
|
||||
}
|
||||
const char* buf = _header->_space[i]._base;
|
||||
size_t sz = _header->_space[i]._used;
|
||||
int crc = ClassLoader::crc32(0, buf, (jint)sz);
|
||||
if (crc != _header->_space[i]._crc) {
|
||||
fail_continue("Checksum verification failed.");
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
// Unmap a memory region in the address space.
|
||||
|
||||
@ -629,7 +652,21 @@ bool FileMapInfo::initialize() {
|
||||
return true;
|
||||
}
|
||||
|
||||
int FileMapInfo::FileMapHeader::compute_crc() {
|
||||
char* header = data();
|
||||
// start computing from the field after _crc
|
||||
char* buf = (char*)&_crc + sizeof(int);
|
||||
size_t sz = data_size() - (buf - header);
|
||||
int crc = ClassLoader::crc32(0, buf, (jint)sz);
|
||||
return crc;
|
||||
}
|
||||
|
||||
bool FileMapInfo::FileMapHeader::validate() {
|
||||
if (VerifySharedSpaces && compute_crc() != _crc) {
|
||||
fail_continue("Header checksum verification failed.");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (_version != current_version()) {
|
||||
FileMapInfo::fail_continue("The shared archive file is the wrong version.");
|
||||
return false;
|
||||
|
@ -61,7 +61,7 @@ private:
|
||||
|
||||
bool _file_open;
|
||||
int _fd;
|
||||
long _file_offset;
|
||||
size_t _file_offset;
|
||||
|
||||
private:
|
||||
static SharedClassPathEntry* _classpath_entry_table;
|
||||
@ -87,12 +87,14 @@ public:
|
||||
}
|
||||
|
||||
int _magic; // identify file type.
|
||||
int _crc; // header crc checksum.
|
||||
int _version; // (from enum, above.)
|
||||
size_t _alignment; // how shared archive should be aligned
|
||||
int _obj_alignment; // value of ObjectAlignmentInBytes
|
||||
|
||||
struct space_info {
|
||||
int _file_offset; // sizeof(this) rounded to vm page size
|
||||
int _crc; // crc checksum of the current space
|
||||
size_t _file_offset; // sizeof(this) rounded to vm page size
|
||||
char* _base; // copy-on-write base address
|
||||
size_t _capacity; // for validity checking
|
||||
size_t _used; // for setting space top on read
|
||||
@ -135,6 +137,7 @@ public:
|
||||
|
||||
virtual bool validate();
|
||||
virtual void populate(FileMapInfo* info, size_t alignment);
|
||||
int compute_crc();
|
||||
};
|
||||
|
||||
FileMapHeader * _header;
|
||||
@ -153,6 +156,8 @@ public:
|
||||
~FileMapInfo();
|
||||
|
||||
static int current_version() { return _current_version; }
|
||||
int compute_header_crc() { return _header->compute_crc(); }
|
||||
void set_header_crc(int crc) { _header->_crc = crc; }
|
||||
void populate_header(size_t alignment);
|
||||
bool validate_header();
|
||||
void invalidate();
|
||||
@ -181,6 +186,7 @@ public:
|
||||
void write_bytes_aligned(const void* buffer, int count);
|
||||
char* map_region(int i);
|
||||
void unmap_region(int i);
|
||||
bool verify_region_checksum(int i);
|
||||
void close();
|
||||
bool is_open() { return _file_open; }
|
||||
ReservedSpace reserve_shared_memory();
|
||||
|
@ -608,6 +608,7 @@ void VM_PopulateDumpSharedSpace::doit() {
|
||||
|
||||
// Pass 2 - write data.
|
||||
mapinfo->open_for_write();
|
||||
mapinfo->set_header_crc(mapinfo->compute_header_crc());
|
||||
mapinfo->write_header();
|
||||
mapinfo->write_space(MetaspaceShared::ro, _loader_data->ro_metaspace(), true);
|
||||
mapinfo->write_space(MetaspaceShared::rw, _loader_data->rw_metaspace(), false);
|
||||
@ -937,9 +938,13 @@ bool MetaspaceShared::map_shared_spaces(FileMapInfo* mapinfo) {
|
||||
|
||||
// Map each shared region
|
||||
if ((_ro_base = mapinfo->map_region(ro)) != NULL &&
|
||||
mapinfo->verify_region_checksum(ro) &&
|
||||
(_rw_base = mapinfo->map_region(rw)) != NULL &&
|
||||
mapinfo->verify_region_checksum(rw) &&
|
||||
(_md_base = mapinfo->map_region(md)) != NULL &&
|
||||
mapinfo->verify_region_checksum(md) &&
|
||||
(_mc_base = mapinfo->map_region(mc)) != NULL &&
|
||||
mapinfo->verify_region_checksum(mc) &&
|
||||
(image_alignment == (size_t)max_alignment()) &&
|
||||
mapinfo->validate_classpath_entry_table()) {
|
||||
// Success (no need to do anything)
|
||||
|
@ -64,6 +64,13 @@ oop ArrayKlass::multi_allocate(int rank, jint* sizes, TRAPS) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// find field according to JVM spec 5.4.3.2, returns the klass in which the field is defined
|
||||
Klass* ArrayKlass::find_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const {
|
||||
// There are no fields in an array klass but look to the super class (Object)
|
||||
assert(super(), "super klass must be present");
|
||||
return super()->find_field(name, sig, fd);
|
||||
}
|
||||
|
||||
Method* ArrayKlass::uncached_lookup_method(Symbol* name, Symbol* signature, MethodLookupMode mode) const {
|
||||
// There are no methods in an array klass but the super class (Object) has some
|
||||
assert(super(), "super klass must be present");
|
||||
|
@ -28,6 +28,7 @@
|
||||
#include "memory/universe.hpp"
|
||||
#include "oops/klass.hpp"
|
||||
|
||||
class fieldDescriptor;
|
||||
class klassVtable;
|
||||
|
||||
// ArrayKlass is the abstract baseclass for all array classes
|
||||
@ -77,6 +78,9 @@ class ArrayKlass: public Klass {
|
||||
virtual oop multi_allocate(int rank, jint* sizes, TRAPS);
|
||||
objArrayOop allocate_arrayArray(int n, int length, TRAPS);
|
||||
|
||||
// find field according to JVM spec 5.4.3.2, returns the klass in which the field is defined
|
||||
Klass* find_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const;
|
||||
|
||||
// Lookup operations
|
||||
Method* uncached_lookup_method(Symbol* name, Symbol* signature, MethodLookupMode mode) const;
|
||||
|
||||
|
@ -130,6 +130,15 @@ bool Klass::compute_is_subtype_of(Klass* k) {
|
||||
return is_subclass_of(k);
|
||||
}
|
||||
|
||||
Klass* Klass::find_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const {
|
||||
#ifdef ASSERT
|
||||
tty->print_cr("Error: find_field called on a klass oop."
|
||||
" Likely error: reflection method does not correctly"
|
||||
" wrap return value in a mirror object.");
|
||||
#endif
|
||||
ShouldNotReachHere();
|
||||
return NULL;
|
||||
}
|
||||
|
||||
Method* Klass::uncached_lookup_method(Symbol* name, Symbol* signature, MethodLookupMode mode) const {
|
||||
#ifdef ASSERT
|
||||
|
@ -62,6 +62,7 @@ class ClassLoaderData;
|
||||
class klassVtable;
|
||||
class ParCompactionManager;
|
||||
class KlassSizeStats;
|
||||
class fieldDescriptor;
|
||||
|
||||
class Klass : public Metadata {
|
||||
friend class VMStructs;
|
||||
@ -411,6 +412,7 @@ protected:
|
||||
virtual void initialize(TRAPS);
|
||||
// lookup operation for MethodLookupCache
|
||||
friend class MethodLookupCache;
|
||||
virtual Klass* find_field(Symbol* name, Symbol* signature, fieldDescriptor* fd) const;
|
||||
virtual Method* uncached_lookup_method(Symbol* name, Symbol* signature, MethodLookupMode mode) const;
|
||||
public:
|
||||
Method* lookup_method(Symbol* name, Symbol* signature) const {
|
||||
|
@ -1153,12 +1153,18 @@ void Compile::init_start(StartNode* s) {
|
||||
assert(s == start(), "");
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the 'StartNode'. We must not have a pending failure, since the ideal graph
|
||||
* can be in an inconsistent state, i.e., we can get segmentation faults when traversing
|
||||
* the ideal graph.
|
||||
*/
|
||||
StartNode* Compile::start() const {
|
||||
assert(!failing(), "");
|
||||
assert (!failing(), err_msg_res("Must not have pending failure. Reason is: %s", failure_reason()));
|
||||
for (DUIterator_Fast imax, i = root()->fast_outs(imax); i < imax; i++) {
|
||||
Node* start = root()->fast_out(i);
|
||||
if( start->is_Start() )
|
||||
if (start->is_Start()) {
|
||||
return start->as_Start();
|
||||
}
|
||||
}
|
||||
fatal("Did not find Start node!");
|
||||
return NULL;
|
||||
|
@ -707,12 +707,15 @@ class Compile : public Phase {
|
||||
void sort_expensive_nodes();
|
||||
|
||||
// Compilation environment.
|
||||
Arena* comp_arena() { return &_comp_arena; }
|
||||
ciEnv* env() const { return _env; }
|
||||
CompileLog* log() const { return _log; }
|
||||
bool failing() const { return _env->failing() || _failure_reason != NULL; }
|
||||
const char* failure_reason() { return _failure_reason; }
|
||||
bool failure_reason_is(const char* r) { return (r==_failure_reason) || (r!=NULL && _failure_reason!=NULL && strcmp(r, _failure_reason)==0); }
|
||||
Arena* comp_arena() { return &_comp_arena; }
|
||||
ciEnv* env() const { return _env; }
|
||||
CompileLog* log() const { return _log; }
|
||||
bool failing() const { return _env->failing() || _failure_reason != NULL; }
|
||||
const char* failure_reason() const { return (_env->failing()) ? _env->failure_reason() : _failure_reason; }
|
||||
|
||||
bool failure_reason_is(const char* r) const {
|
||||
return (r == _failure_reason) || (r != NULL && _failure_reason != NULL && strcmp(r, _failure_reason) == 0);
|
||||
}
|
||||
|
||||
void record_failure(const char* reason);
|
||||
void record_method_not_compilable(const char* reason, bool all_tiers = false) {
|
||||
|
@ -802,10 +802,16 @@ void Parse::catch_inline_exceptions(SafePointNode* ex_map) {
|
||||
// each arm of the Phi. If I know something clever about the exceptions
|
||||
// I'm loading the class from, I can replace the LoadKlass with the
|
||||
// klass constant for the exception oop.
|
||||
if( ex_node->is_Phi() ) {
|
||||
ex_klass_node = new PhiNode( ex_node->in(0), TypeKlassPtr::OBJECT );
|
||||
for( uint i = 1; i < ex_node->req(); i++ ) {
|
||||
Node* p = basic_plus_adr( ex_node->in(i), ex_node->in(i), oopDesc::klass_offset_in_bytes() );
|
||||
if (ex_node->is_Phi()) {
|
||||
ex_klass_node = new PhiNode(ex_node->in(0), TypeKlassPtr::OBJECT);
|
||||
for (uint i = 1; i < ex_node->req(); i++) {
|
||||
Node* ex_in = ex_node->in(i);
|
||||
if (ex_in == top() || ex_in == NULL) {
|
||||
// This path was not taken.
|
||||
ex_klass_node->init_req(i, top());
|
||||
continue;
|
||||
}
|
||||
Node* p = basic_plus_adr(ex_in, ex_in, oopDesc::klass_offset_in_bytes());
|
||||
Node* k = _gvn.transform( LoadKlassNode::make(_gvn, immutable_memory(), p, TypeInstPtr::KLASS, TypeKlassPtr::OBJECT) );
|
||||
ex_klass_node->init_req( i, k );
|
||||
}
|
||||
|
@ -805,6 +805,7 @@ JVM_ENTRY(jclass, JVM_FindClassFromBootLoader(JNIEnv* env,
|
||||
return (jclass) JNIHandles::make_local(env, k->java_mirror());
|
||||
JVM_END
|
||||
|
||||
// Not used; JVM_FindClassFromCaller replaces this.
|
||||
JVM_ENTRY(jclass, JVM_FindClassFromClassLoader(JNIEnv* env, const char* name,
|
||||
jboolean init, jobject loader,
|
||||
jboolean throwError))
|
||||
@ -831,6 +832,42 @@ JVM_ENTRY(jclass, JVM_FindClassFromClassLoader(JNIEnv* env, const char* name,
|
||||
return result;
|
||||
JVM_END
|
||||
|
||||
// Find a class with this name in this loader, using the caller's protection domain.
|
||||
JVM_ENTRY(jclass, JVM_FindClassFromCaller(JNIEnv* env, const char* name,
|
||||
jboolean init, jobject loader,
|
||||
jclass caller))
|
||||
JVMWrapper2("JVM_FindClassFromCaller %s throws ClassNotFoundException", name);
|
||||
// Java libraries should ensure that name is never null...
|
||||
if (name == NULL || (int)strlen(name) > Symbol::max_length()) {
|
||||
// It's impossible to create this class; the name cannot fit
|
||||
// into the constant pool.
|
||||
THROW_MSG_0(vmSymbols::java_lang_ClassNotFoundException(), name);
|
||||
}
|
||||
|
||||
TempNewSymbol h_name = SymbolTable::new_symbol(name, CHECK_NULL);
|
||||
|
||||
oop loader_oop = JNIHandles::resolve(loader);
|
||||
oop from_class = JNIHandles::resolve(caller);
|
||||
oop protection_domain = NULL;
|
||||
// If loader is null, shouldn't call ClassLoader.checkPackageAccess; otherwise get
|
||||
// NPE. Put it in another way, the bootstrap class loader has all permission and
|
||||
// thus no checkPackageAccess equivalence in the VM class loader.
|
||||
// The caller is also passed as NULL by the java code if there is no security
|
||||
// manager to avoid the performance cost of getting the calling class.
|
||||
if (from_class != NULL && loader_oop != NULL) {
|
||||
protection_domain = java_lang_Class::as_Klass(from_class)->protection_domain();
|
||||
}
|
||||
|
||||
Handle h_loader(THREAD, loader_oop);
|
||||
Handle h_prot(THREAD, protection_domain);
|
||||
jclass result = find_class_from_class_loader(env, h_name, init, h_loader,
|
||||
h_prot, false, THREAD);
|
||||
|
||||
if (TraceClassResolution && result != NULL) {
|
||||
trace_class_resolution(java_lang_Class::as_Klass(JNIHandles::resolve_non_null(result)));
|
||||
}
|
||||
return result;
|
||||
JVM_END
|
||||
|
||||
JVM_ENTRY(jclass, JVM_FindClassFromClass(JNIEnv *env, const char *name,
|
||||
jboolean init, jclass from))
|
||||
@ -1073,17 +1110,6 @@ JVM_ENTRY(jobjectArray, JVM_GetClassInterfaces(JNIEnv *env, jclass cls))
|
||||
JVM_END
|
||||
|
||||
|
||||
JVM_ENTRY(jobject, JVM_GetClassLoader(JNIEnv *env, jclass cls))
|
||||
JVMWrapper("JVM_GetClassLoader");
|
||||
if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) {
|
||||
return NULL;
|
||||
}
|
||||
Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls));
|
||||
oop loader = k->class_loader();
|
||||
return JNIHandles::make_local(env, loader);
|
||||
JVM_END
|
||||
|
||||
|
||||
JVM_QUICK_ENTRY(jboolean, JVM_IsInterface(JNIEnv *env, jclass cls))
|
||||
JVMWrapper("JVM_IsInterface");
|
||||
oop mirror = JNIHandles::resolve_non_null(cls);
|
||||
@ -3932,10 +3958,15 @@ JNIEXPORT void JNICALL JVM_RawMonitorExit(void *mon) {
|
||||
|
||||
// Shared JNI/JVM entry points //////////////////////////////////////////////////////////////
|
||||
|
||||
jclass find_class_from_class_loader(JNIEnv* env, Symbol* name, jboolean init, Handle loader, Handle protection_domain, jboolean throwError, TRAPS) {
|
||||
jclass find_class_from_class_loader(JNIEnv* env, Symbol* name, jboolean init,
|
||||
Handle loader, Handle protection_domain,
|
||||
jboolean throwError, TRAPS) {
|
||||
// Security Note:
|
||||
// The Java level wrapper will perform the necessary security check allowing
|
||||
// us to pass the NULL as the initiating class loader.
|
||||
// us to pass the NULL as the initiating class loader. The VM is responsible for
|
||||
// the checkPackageAccess relative to the initiating class loader via the
|
||||
// protection_domain. The protection_domain is passed as NULL by the java code
|
||||
// if there is no security manager in 3-arg Class.forName().
|
||||
Klass* klass = SystemDictionary::resolve_or_fail(name, loader, protection_domain, throwError != 0, CHECK_NULL);
|
||||
|
||||
KlassHandle klass_handle(THREAD, klass);
|
||||
|
@ -419,6 +419,19 @@ JVM_FindClassFromClassLoader(JNIEnv *env, const char *name, jboolean init,
|
||||
JNIEXPORT jclass JNICALL
|
||||
JVM_FindClassFromBootLoader(JNIEnv *env, const char *name);
|
||||
|
||||
/*
|
||||
* Find a class from a given class loader. Throws ClassNotFoundException.
|
||||
* name: name of class
|
||||
* init: whether initialization is done
|
||||
* loader: class loader to look up the class. This may not be the same as the caller's
|
||||
* class loader.
|
||||
* caller: initiating class. The initiating class may be null when a security
|
||||
* manager is not installed.
|
||||
*/
|
||||
JNIEXPORT jclass JNICALL
|
||||
JVM_FindClassFromCaller(JNIEnv *env, const char *name, jboolean init,
|
||||
jobject loader, jclass caller);
|
||||
|
||||
/*
|
||||
* Find a class from a given class.
|
||||
*/
|
||||
@ -462,9 +475,6 @@ JVM_GetClassName(JNIEnv *env, jclass cls);
|
||||
JNIEXPORT jobjectArray JNICALL
|
||||
JVM_GetClassInterfaces(JNIEnv *env, jclass cls);
|
||||
|
||||
JNIEXPORT jobject JNICALL
|
||||
JVM_GetClassLoader(JNIEnv *env, jclass cls);
|
||||
|
||||
JNIEXPORT jboolean JNICALL
|
||||
JVM_IsInterface(JNIEnv *env, jclass cls);
|
||||
|
||||
|
@ -3836,6 +3836,11 @@ jint Arguments::parse(const JavaVMInitArgs* args) {
|
||||
return JNI_ENOMEM;
|
||||
}
|
||||
|
||||
// Set up VerifySharedSpaces
|
||||
if (FLAG_IS_DEFAULT(VerifySharedSpaces) && SharedArchiveFile != NULL) {
|
||||
VerifySharedSpaces = true;
|
||||
}
|
||||
|
||||
// Delay warning until here so that we've had a chance to process
|
||||
// the -XX:-PrintWarnings flag
|
||||
if (needs_hotspotrc_warning) {
|
||||
|
@ -1177,11 +1177,11 @@ class CommandLineFlags {
|
||||
"When true prevents OS-level spurious, or premature, wakeups " \
|
||||
"from Object.wait (Ignored for Windows)") \
|
||||
\
|
||||
product(intx, NativeMonitorTimeout, -1, "(Unstable)") \
|
||||
experimental(intx, NativeMonitorTimeout, -1, "(Unstable)") \
|
||||
\
|
||||
product(intx, NativeMonitorFlags, 0, "(Unstable)") \
|
||||
experimental(intx, NativeMonitorFlags, 0, "(Unstable)") \
|
||||
\
|
||||
product(intx, NativeMonitorSpinLimit, 20, "(Unstable)") \
|
||||
experimental(intx, NativeMonitorSpinLimit, 20, "(Unstable)") \
|
||||
\
|
||||
develop(bool, UsePthreads, false, \
|
||||
"Use pthread-based instead of libthread-based synchronization " \
|
||||
@ -3790,6 +3790,10 @@ class CommandLineFlags {
|
||||
product(bool, UseSharedSpaces, true, \
|
||||
"Use shared spaces for metadata") \
|
||||
\
|
||||
product(bool, VerifySharedSpaces, false, \
|
||||
"Verify shared spaces (false for default archive, true for " \
|
||||
"archive specified by -XX:SharedArchiveFile)") \
|
||||
\
|
||||
product(bool, RequireSharedSpaces, false, \
|
||||
"Require shared spaces for metadata") \
|
||||
\
|
||||
|
@ -155,9 +155,6 @@ class PerfMemory : AllStatic {
|
||||
}
|
||||
}
|
||||
|
||||
// filename of backing store or NULL if none.
|
||||
static char* backing_store_filename();
|
||||
|
||||
// returns the complete file path of hsperfdata.
|
||||
// the caller is expected to free the allocated memory.
|
||||
static char* get_perfdata_file_path();
|
||||
|
@ -507,7 +507,8 @@ bool Reflection::verify_field_access(Klass* current_class,
|
||||
if (access.is_protected()) {
|
||||
if (!protected_restriction) {
|
||||
// See if current_class (or outermost host class) is a subclass of field_class
|
||||
if (host_class->is_subclass_of(field_class)) {
|
||||
// An interface may not access protected members of j.l.Object
|
||||
if (!host_class->is_interface() && host_class->is_subclass_of(field_class)) {
|
||||
if (access.is_static() || // static fields are ok, see 6622385
|
||||
current_class == resolved_class ||
|
||||
field_class == resolved_class ||
|
||||
|
@ -540,17 +540,25 @@ int NMethodSweeper::process_nmethod(nmethod *nm) {
|
||||
// If there are no current activations of this method on the
|
||||
// stack we can safely convert it to a zombie method
|
||||
if (nm->can_not_entrant_be_converted()) {
|
||||
if (PrintMethodFlushing && Verbose) {
|
||||
tty->print_cr("### Nmethod %3d/" PTR_FORMAT " (not entrant) being made zombie", nm->compile_id(), nm);
|
||||
}
|
||||
// Clear ICStubs to prevent back patching stubs of zombie or unloaded
|
||||
// nmethods during the next safepoint (see ICStub::finalize).
|
||||
MutexLocker cl(CompiledIC_lock);
|
||||
nm->clear_ic_stubs();
|
||||
// Code cache state change is tracked in make_zombie()
|
||||
nm->make_zombie();
|
||||
_zombified_count++;
|
||||
SWEEP(nm);
|
||||
{
|
||||
MutexLocker cl(CompiledIC_lock);
|
||||
nm->clear_ic_stubs();
|
||||
}
|
||||
// Acquiring the CompiledIC_lock may block for a safepoint and set the
|
||||
// nmethod to zombie (see 'CodeCache::make_marked_nmethods_zombies').
|
||||
// Check if nmethod is still non-entrant at this point.
|
||||
if (nm->is_not_entrant()) {
|
||||
if (PrintMethodFlushing && Verbose) {
|
||||
tty->print_cr("### Nmethod %3d/" PTR_FORMAT " (not entrant) being made zombie", nm->compile_id(), nm);
|
||||
}
|
||||
// Code cache state change is tracked in make_zombie()
|
||||
nm->make_zombie();
|
||||
_zombified_count++;
|
||||
SWEEP(nm);
|
||||
}
|
||||
assert(nm->is_zombie(), "nmethod must be zombie");
|
||||
} else {
|
||||
// Still alive, clean up its inline caches
|
||||
MutexLocker cl(CompiledIC_lock);
|
||||
|
@ -447,7 +447,7 @@ hotspot_compiler_3 = \
|
||||
compiler/codegen/ \
|
||||
compiler/cpuflags/RestoreMXCSR.java \
|
||||
compiler/EscapeAnalysis/ \
|
||||
compiler/exceptions/TestRecursiveReplacedException.java \
|
||||
compiler/exceptions/ \
|
||||
compiler/floatingpoint/ModNaN.java \
|
||||
compiler/gcbarriers/G1CrashTest.java \
|
||||
compiler/inlining/ \
|
||||
|
@ -38,22 +38,26 @@ public class CheckSegmentedCodeCache {
|
||||
|
||||
private static void verifySegmentedCodeCache(ProcessBuilder pb, boolean enabled) throws Exception {
|
||||
OutputAnalyzer out = new OutputAnalyzer(pb.start());
|
||||
out.shouldHaveExitValue(0);
|
||||
if (enabled) {
|
||||
try {
|
||||
// Non-nmethod code heap should be always available with the segmented code cache
|
||||
out.shouldContain(NON_METHOD);
|
||||
} catch (RuntimeException e) {
|
||||
// TieredCompilation is disabled in a client VM
|
||||
out.shouldContain("TieredCompilation is disabled in this release.");
|
||||
// Check if TieredCompilation is disabled (in a client VM)
|
||||
if(!out.getOutput().contains("TieredCompilation is disabled in this release.")) {
|
||||
// Code cache is not segmented
|
||||
throw new RuntimeException("No code cache segmentation.");
|
||||
}
|
||||
}
|
||||
} else {
|
||||
out.shouldNotContain(NON_METHOD);
|
||||
}
|
||||
out.shouldHaveExitValue(0);
|
||||
}
|
||||
|
||||
private static void verifyCodeHeapNotExists(ProcessBuilder pb, String... heapNames) throws Exception {
|
||||
OutputAnalyzer out = new OutputAnalyzer(pb.start());
|
||||
out.shouldHaveExitValue(0);
|
||||
for (String name : heapNames) {
|
||||
out.shouldNotContain(name);
|
||||
}
|
||||
@ -86,6 +90,10 @@ public class CheckSegmentedCodeCache {
|
||||
"-XX:ReservedCodeCacheSize=240m",
|
||||
"-XX:+PrintCodeCache", "-version");
|
||||
verifySegmentedCodeCache(pb, true);
|
||||
pb = ProcessTools.createJavaProcessBuilder("-XX:+TieredCompilation",
|
||||
"-XX:ReservedCodeCacheSize=400m",
|
||||
"-XX:+PrintCodeCache", "-version");
|
||||
verifySegmentedCodeCache(pb, true);
|
||||
|
||||
// Always enabled if SegmentedCodeCache is set
|
||||
pb = ProcessTools.createJavaProcessBuilder("-XX:+SegmentedCodeCache",
|
||||
@ -100,12 +108,13 @@ public class CheckSegmentedCodeCache {
|
||||
"-Xint",
|
||||
"-XX:+PrintCodeCache", "-version");
|
||||
verifyCodeHeapNotExists(pb, PROFILED, NON_PROFILED);
|
||||
|
||||
// If we stop compilation at CompLevel_none or CompLevel_simple we
|
||||
// don't need a profiled code heap.
|
||||
pb = ProcessTools.createJavaProcessBuilder("-XX:+SegmentedCodeCache",
|
||||
"-XX:TieredStopAtLevel=0",
|
||||
"-XX:+PrintCodeCache", "-version");
|
||||
verifyCodeHeapNotExists(pb, PROFILED, NON_PROFILED);
|
||||
|
||||
// If we stop compilation at CompLevel_simple
|
||||
verifyCodeHeapNotExists(pb, PROFILED);
|
||||
pb = ProcessTools.createJavaProcessBuilder("-XX:+SegmentedCodeCache",
|
||||
"-XX:TieredStopAtLevel=1",
|
||||
"-XX:+PrintCodeCache", "-version");
|
||||
|
81
hotspot/test/compiler/exceptions/CatchInlineExceptions.java
Normal file
81
hotspot/test/compiler/exceptions/CatchInlineExceptions.java
Normal file
@ -0,0 +1,81 @@
|
||||
/*
|
||||
* Copyright (c) 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.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @test
|
||||
* @bug 8059299
|
||||
* @summary assert(adr_type != NULL) failed: expecting TypeKlassPtr
|
||||
* @run main/othervm -Xbatch CatchInlineExceptions
|
||||
*/
|
||||
|
||||
class Exception1 extends Exception {};
|
||||
class Exception2 extends Exception {};
|
||||
|
||||
public class CatchInlineExceptions {
|
||||
private static int counter0;
|
||||
private static int counter1;
|
||||
private static int counter2;
|
||||
private static int counter;
|
||||
|
||||
static void foo(int i) throws Exception {
|
||||
if ((i & 1023) == 2) {
|
||||
counter0++;
|
||||
throw new Exception2();
|
||||
}
|
||||
}
|
||||
|
||||
static void test(int i) throws Exception {
|
||||
try {
|
||||
foo(i);
|
||||
}
|
||||
catch (Exception e) {
|
||||
if (e instanceof Exception1) {
|
||||
counter1++;
|
||||
} else if (e instanceof Exception2) {
|
||||
counter2++;
|
||||
}
|
||||
counter++;
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws Throwable {
|
||||
for (int i = 0; i < 15000; i++) {
|
||||
try {
|
||||
test(i);
|
||||
} catch (Exception e) {
|
||||
// expected
|
||||
}
|
||||
}
|
||||
if (counter1 != 0) {
|
||||
throw new RuntimeException("Failed: counter1(" + counter1 + ") != 0");
|
||||
}
|
||||
if (counter2 != counter) {
|
||||
throw new RuntimeException("Failed: counter2(" + counter2 + ") != counter0(" + counter0 + ")");
|
||||
}
|
||||
if (counter2 != counter) {
|
||||
throw new RuntimeException("Failed: counter2(" + counter2 + ") != counter(" + counter + ")");
|
||||
}
|
||||
System.out.println("TEST PASSED");
|
||||
}
|
||||
}
|
@ -277,3 +277,4 @@ d181d4002214e4914d5525bd5ee13369311c765c jdk9-b30
|
||||
b940ca3d2c7e8a279ca850706b89c2ad3a841e82 jdk9-b32
|
||||
46b360454dadbb329d42c59bb8192daeb9d59875 jdk9-b33
|
||||
6b343b9b7a7008f5f699a2d99881163cab7a2986 jdk9-b34
|
||||
b9370464572fc663a38956047aa612d6e7854c3d jdk9-b35
|
||||
|
@ -1,13 +1,13 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
* Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -51,8 +51,6 @@ import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.Locale;
|
||||
import java.util.Vector;
|
||||
import javax.xml.XMLConstants;
|
||||
import org.w3c.dom.DOMConfiguration;
|
||||
import org.w3c.dom.DOMErrorHandler;
|
||||
import org.w3c.dom.DOMException;
|
||||
@ -976,41 +974,40 @@ public class DOMConfigurationImpl extends ParserConfigurationSettings
|
||||
*/
|
||||
public DOMStringList getParameterNames() {
|
||||
if (fRecognizedParameters == null){
|
||||
Vector parameters = new Vector();
|
||||
ArrayList parameters = new ArrayList();
|
||||
|
||||
//Add DOM recognized parameters
|
||||
//REVISIT: Would have been nice to have a list of
|
||||
//recognized paramters.
|
||||
parameters.add(Constants.DOM_COMMENTS);
|
||||
parameters.add(Constants.DOM_DATATYPE_NORMALIZATION);
|
||||
parameters.add(Constants.DOM_CDATA_SECTIONS);
|
||||
parameters.add(Constants.DOM_ENTITIES);
|
||||
parameters.add(Constants.DOM_SPLIT_CDATA);
|
||||
parameters.add(Constants.DOM_NAMESPACES);
|
||||
parameters.add(Constants.DOM_VALIDATE);
|
||||
//Add DOM recognized parameters
|
||||
//REVISIT: Would have been nice to have a list of
|
||||
//recognized paramters.
|
||||
parameters.add(Constants.DOM_COMMENTS);
|
||||
parameters.add(Constants.DOM_DATATYPE_NORMALIZATION);
|
||||
parameters.add(Constants.DOM_CDATA_SECTIONS);
|
||||
parameters.add(Constants.DOM_ENTITIES);
|
||||
parameters.add(Constants.DOM_SPLIT_CDATA);
|
||||
parameters.add(Constants.DOM_NAMESPACES);
|
||||
parameters.add(Constants.DOM_VALIDATE);
|
||||
|
||||
parameters.add(Constants.DOM_INFOSET);
|
||||
parameters.add(Constants.DOM_NORMALIZE_CHARACTERS);
|
||||
parameters.add(Constants.DOM_CANONICAL_FORM);
|
||||
parameters.add(Constants.DOM_VALIDATE_IF_SCHEMA);
|
||||
parameters.add(Constants.DOM_CHECK_CHAR_NORMALIZATION);
|
||||
parameters.add(Constants.DOM_WELLFORMED);
|
||||
parameters.add(Constants.DOM_INFOSET);
|
||||
parameters.add(Constants.DOM_NORMALIZE_CHARACTERS);
|
||||
parameters.add(Constants.DOM_CANONICAL_FORM);
|
||||
parameters.add(Constants.DOM_VALIDATE_IF_SCHEMA);
|
||||
parameters.add(Constants.DOM_CHECK_CHAR_NORMALIZATION);
|
||||
parameters.add(Constants.DOM_WELLFORMED);
|
||||
|
||||
parameters.add(Constants.DOM_NAMESPACE_DECLARATIONS);
|
||||
parameters.add(Constants.DOM_ELEMENT_CONTENT_WHITESPACE);
|
||||
parameters.add(Constants.DOM_NAMESPACE_DECLARATIONS);
|
||||
parameters.add(Constants.DOM_ELEMENT_CONTENT_WHITESPACE);
|
||||
|
||||
parameters.add(Constants.DOM_ERROR_HANDLER);
|
||||
parameters.add(Constants.DOM_SCHEMA_TYPE);
|
||||
parameters.add(Constants.DOM_SCHEMA_LOCATION);
|
||||
parameters.add(Constants.DOM_RESOURCE_RESOLVER);
|
||||
parameters.add(Constants.DOM_ERROR_HANDLER);
|
||||
parameters.add(Constants.DOM_SCHEMA_TYPE);
|
||||
parameters.add(Constants.DOM_SCHEMA_LOCATION);
|
||||
parameters.add(Constants.DOM_RESOURCE_RESOLVER);
|
||||
|
||||
//Add recognized xerces features and properties
|
||||
parameters.add(GRAMMAR_POOL);
|
||||
parameters.add(SYMBOL_TABLE);
|
||||
parameters.add(SEND_PSVI);
|
||||
|
||||
fRecognizedParameters = new DOMStringListImpl(parameters);
|
||||
//Add recognized xerces features and properties
|
||||
parameters.add(GRAMMAR_POOL);
|
||||
parameters.add(SYMBOL_TABLE);
|
||||
parameters.add(SEND_PSVI);
|
||||
|
||||
fRecognizedParameters = new DOMStringListImpl(parameters);
|
||||
}
|
||||
|
||||
return fRecognizedParameters;
|
||||
|
@ -1,13 +1,10 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2002-2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,14 +17,16 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.dom;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.AttributePSVImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.*;
|
||||
import com.sun.org.apache.xerces.internal.xs.AttributePSVI;
|
||||
import java.io.IOException;
|
||||
import java.io.NotSerializableException;
|
||||
import java.io.ObjectInputStream;
|
||||
import java.io.ObjectOutputStream;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.xs.AttributePSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.*;
|
||||
|
||||
/**
|
||||
* Attribute namespace implementation; stores PSVI attribute items.
|
||||
*
|
||||
@ -67,20 +66,8 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
* value in the original document, this is true; otherwise, it is false */
|
||||
protected boolean fSpecified = true;
|
||||
|
||||
/** schema normalized value property */
|
||||
protected String fNormalizedValue = null;
|
||||
|
||||
/** schema actual value */
|
||||
protected Object fActualValue = null;
|
||||
|
||||
/** schema actual value type */
|
||||
protected short fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
|
||||
/** actual value types if the value is a list */
|
||||
protected ShortList fItemValueTypes = null;
|
||||
|
||||
/** member type definition against which attribute was validated */
|
||||
protected XSSimpleTypeDefinition fMemberType = null;
|
||||
/** Schema value */
|
||||
protected ValidatedInfo fValue = new ValidatedInfo();
|
||||
|
||||
/** validation attempted: none, partial, full */
|
||||
protected short fValidationAttempted = AttributePSVI.VALIDATION_NONE;
|
||||
@ -91,6 +78,9 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
/** error codes */
|
||||
protected StringList fErrorCodes = null;
|
||||
|
||||
/** error messages */
|
||||
protected StringList fErrorMessages = null;
|
||||
|
||||
/** validation context: could be QName or XPath expression*/
|
||||
protected String fValidationContext = null;
|
||||
|
||||
@ -98,6 +88,20 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
// AttributePSVI methods
|
||||
//
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.apache.xerces.xs.ItemPSVI#constant()
|
||||
*/
|
||||
public ItemPSVI constant() {
|
||||
return new AttributePSVImpl(true, this);
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.apache.xerces.xs.ItemPSVI#isConstant()
|
||||
*/
|
||||
public boolean isConstant() {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* [schema default]
|
||||
*
|
||||
@ -116,7 +120,7 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
* @return the normalized value of this item after validation
|
||||
*/
|
||||
public String getSchemaNormalizedValue() {
|
||||
return fNormalizedValue;
|
||||
return fValue.getNormalizedValue();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -157,7 +161,23 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
* @return list of error codes
|
||||
*/
|
||||
public StringList getErrorCodes() {
|
||||
return fErrorCodes;
|
||||
if (fErrorCodes != null) {
|
||||
return fErrorCodes;
|
||||
}
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
/**
|
||||
* A list of error messages generated from the validation attempt or
|
||||
* an empty <code>StringList</code> if no errors occurred during the
|
||||
* validation attempt. The indices of error messages in this list are
|
||||
* aligned with those in the <code>[schema error code]</code> list.
|
||||
*/
|
||||
public StringList getErrorMessages() {
|
||||
if (fErrorMessages != null) {
|
||||
return fErrorMessages;
|
||||
}
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
// This is the only information we can provide in a pipeline.
|
||||
@ -177,14 +197,14 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
/**
|
||||
* If and only if that type definition is a simple type definition
|
||||
* with {variety} union, or a complex type definition whose {content type}
|
||||
* is a simple thype definition with {variety} union, then an item isomorphic
|
||||
* is a simple type definition with {variety} union, then an item isomorphic
|
||||
* to that member of the union's {member type definitions} which actually
|
||||
* validated the element item's normalized value.
|
||||
*
|
||||
* @return a simple type declaration
|
||||
*/
|
||||
public XSSimpleTypeDefinition getMemberTypeDefinition() {
|
||||
return fMemberType;
|
||||
return fValue.getMemberTypeDefinition();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -208,12 +228,9 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
this.fValidity = attr.getValidity();
|
||||
this.fValidationAttempted = attr.getValidationAttempted();
|
||||
this.fErrorCodes = attr.getErrorCodes();
|
||||
this.fNormalizedValue = attr.getSchemaNormalizedValue();
|
||||
this.fActualValue = attr.getActualNormalizedValue();
|
||||
this.fActualValueType = attr.getActualNormalizedValueType();
|
||||
this.fItemValueTypes = attr.getItemValueTypes();
|
||||
this.fErrorMessages = attr.getErrorMessages();
|
||||
this.fValue.copyFrom(attr.getSchemaValue());
|
||||
this.fTypeDecl = attr.getTypeDefinition();
|
||||
this.fMemberType = attr.getMemberTypeDefinition();
|
||||
this.fSpecified = attr.getIsSchemaSpecified();
|
||||
}
|
||||
|
||||
@ -221,21 +238,28 @@ public class PSVIAttrNSImpl extends AttrNSImpl implements AttributePSVI {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValue()
|
||||
*/
|
||||
public Object getActualNormalizedValue() {
|
||||
return this.fActualValue;
|
||||
return fValue.getActualValue();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValueType()
|
||||
*/
|
||||
public short getActualNormalizedValueType() {
|
||||
return this.fActualValueType;
|
||||
return fValue.getActualValueType();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getItemValueTypes()
|
||||
*/
|
||||
public ShortList getItemValueTypes() {
|
||||
return this.fItemValueTypes;
|
||||
return fValue.getListValueTypes();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.apache.xerces.xs.ItemPSVI#getSchemaValue()
|
||||
*/
|
||||
public XSValue getSchemaValue() {
|
||||
return fValue;
|
||||
}
|
||||
|
||||
// REVISIT: Forbid serialization of PSVI DOM until
|
||||
|
@ -1,13 +1,10 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2002-2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,14 +17,16 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.dom;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.ElementPSVImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.*;
|
||||
import com.sun.org.apache.xerces.internal.xs.ElementPSVI;
|
||||
import java.io.IOException;
|
||||
import java.io.NotSerializableException;
|
||||
import java.io.ObjectInputStream;
|
||||
import java.io.ObjectOutputStream;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.xs.ElementPSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.*;
|
||||
|
||||
/**
|
||||
* Element namespace implementation; stores PSVI element items.
|
||||
*
|
||||
@ -72,24 +71,12 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
*/
|
||||
protected boolean fSpecified = true;
|
||||
|
||||
/** schema normalized value property */
|
||||
protected String fNormalizedValue = null;
|
||||
|
||||
/** schema actual value */
|
||||
protected Object fActualValue = null;
|
||||
|
||||
/** schema actual value type */
|
||||
protected short fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
|
||||
/** actual value types if the value is a list */
|
||||
protected ShortList fItemValueTypes = null;
|
||||
/** Schema value */
|
||||
protected ValidatedInfo fValue = new ValidatedInfo();
|
||||
|
||||
/** http://www.w3.org/TR/xmlschema-1/#e-notation*/
|
||||
protected XSNotationDeclaration fNotation = null;
|
||||
|
||||
/** member type definition against which element was validated */
|
||||
protected XSSimpleTypeDefinition fMemberType = null;
|
||||
|
||||
/** validation attempted: none, partial, full */
|
||||
protected short fValidationAttempted = ElementPSVI.VALIDATION_NONE;
|
||||
|
||||
@ -99,6 +86,9 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
/** error codes */
|
||||
protected StringList fErrorCodes = null;
|
||||
|
||||
/** error messages */
|
||||
protected StringList fErrorMessages = null;
|
||||
|
||||
/** validation context: could be QName or XPath expression*/
|
||||
protected String fValidationContext = null;
|
||||
|
||||
@ -109,6 +99,20 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
// ElementPSVI methods
|
||||
//
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#constant()
|
||||
*/
|
||||
public ItemPSVI constant() {
|
||||
return new ElementPSVImpl(true, this);
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#isConstant()
|
||||
*/
|
||||
public boolean isConstant() {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* [schema default]
|
||||
*
|
||||
@ -127,7 +131,7 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
* @return the normalized value of this item after validation
|
||||
*/
|
||||
public String getSchemaNormalizedValue() {
|
||||
return fNormalizedValue;
|
||||
return fValue.getNormalizedValue();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -167,9 +171,24 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
* @return Array of error codes
|
||||
*/
|
||||
public StringList getErrorCodes() {
|
||||
return fErrorCodes;
|
||||
if (fErrorCodes != null) {
|
||||
return fErrorCodes;
|
||||
}
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
/**
|
||||
* A list of error messages generated from the validation attempt or
|
||||
* an empty <code>StringList</code> if no errors occurred during the
|
||||
* validation attempt. The indices of error messages in this list are
|
||||
* aligned with those in the <code>[schema error code]</code> list.
|
||||
*/
|
||||
public StringList getErrorMessages() {
|
||||
if (fErrorMessages != null) {
|
||||
return fErrorMessages;
|
||||
}
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
// This is the only information we can provide in a pipeline.
|
||||
public String getValidationContext() {
|
||||
@ -213,7 +232,7 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
* @return a simple type declaration
|
||||
*/
|
||||
public XSSimpleTypeDefinition getMemberTypeDefinition() {
|
||||
return fMemberType;
|
||||
return fValue.getMemberTypeDefinition();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -239,7 +258,7 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
/**
|
||||
* Copy PSVI properties from another psvi item.
|
||||
*
|
||||
* @param attr the source of attribute PSVI items
|
||||
* @param elem the source of element PSVI items
|
||||
*/
|
||||
public void setPSVI(ElementPSVI elem) {
|
||||
this.fDeclaration = elem.getElementDeclaration();
|
||||
@ -250,11 +269,15 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
this.fValidity = elem.getValidity();
|
||||
this.fValidationAttempted = elem.getValidationAttempted();
|
||||
this.fErrorCodes = elem.getErrorCodes();
|
||||
this.fNormalizedValue = elem.getSchemaNormalizedValue();
|
||||
this.fActualValue = elem.getActualNormalizedValue();
|
||||
this.fActualValueType = elem.getActualNormalizedValueType();
|
||||
this.fItemValueTypes = elem.getItemValueTypes();
|
||||
this.fMemberType = elem.getMemberTypeDefinition();
|
||||
this.fErrorMessages = elem.getErrorMessages();
|
||||
if (fTypeDecl instanceof XSSimpleTypeDefinition ||
|
||||
fTypeDecl instanceof XSComplexTypeDefinition &&
|
||||
((XSComplexTypeDefinition)fTypeDecl).getContentType() == XSComplexTypeDefinition.CONTENTTYPE_SIMPLE) {
|
||||
this.fValue.copyFrom(elem.getSchemaValue());
|
||||
}
|
||||
else {
|
||||
this.fValue.reset();
|
||||
}
|
||||
this.fSpecified = elem.getIsSchemaSpecified();
|
||||
this.fNil = elem.getNil();
|
||||
}
|
||||
@ -263,21 +286,28 @@ public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValue()
|
||||
*/
|
||||
public Object getActualNormalizedValue() {
|
||||
return this.fActualValue;
|
||||
return fValue.getActualValue();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValueType()
|
||||
*/
|
||||
public short getActualNormalizedValueType() {
|
||||
return this.fActualValueType;
|
||||
return fValue.getActualValueType();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getItemValueTypes()
|
||||
*/
|
||||
public ShortList getItemValueTypes() {
|
||||
return this.fItemValueTypes;
|
||||
return fValue.getListValueTypes();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getSchemaValue()
|
||||
*/
|
||||
public XSValue getSchemaValue() {
|
||||
return fValue;
|
||||
}
|
||||
|
||||
// REVISIT: Forbid serialization of PSVI DOM until
|
||||
|
@ -1,3 +1,6 @@
|
||||
/*
|
||||
* Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||
*/
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
@ -632,9 +635,12 @@ public final class Constants {
|
||||
/** Validation manager property ("internal/validation-manager"). */
|
||||
public static final String VALIDATION_MANAGER_PROPERTY = "internal/validation-manager";
|
||||
|
||||
/** Schema type of the root element in a document ("validation/schema/root-type-definition"). */
|
||||
/** Schema type for the root element in a document ("validation/schema/root-type-definition"). */
|
||||
public static final String ROOT_TYPE_DEFINITION_PROPERTY = "validation/schema/root-type-definition";
|
||||
|
||||
/** Schema element declaration for the root element in a document ("validation/schema/root-element-declaration"). */
|
||||
public static final String ROOT_ELEMENT_DECLARATION_PROPERTY = "validation/schema/root-element-declaration";
|
||||
|
||||
/** XPointer Schema property ("xpointer-schema"). */
|
||||
public static final String XPOINTER_SCHEMA_PROPERTY = "xpointer-schema";
|
||||
|
||||
@ -803,6 +809,7 @@ public final class Constants {
|
||||
BUFFER_SIZE_PROPERTY,
|
||||
SECURITY_MANAGER_PROPERTY,
|
||||
ROOT_TYPE_DEFINITION_PROPERTY,
|
||||
ROOT_ELEMENT_DECLARATION_PROPERTY,
|
||||
LOCALE_PROPERTY,
|
||||
SCHEMA_DV_FACTORY_PROPERTY,
|
||||
};
|
||||
|
@ -611,9 +611,9 @@ public class XMLDocumentFragmentScannerImpl
|
||||
//fElementStack2.clear();
|
||||
//fReplaceEntityReferences = true;
|
||||
//fSupportExternalEntities = true;
|
||||
Boolean bo = (Boolean)propertyManager.getProperty(XMLInputFactoryImpl.IS_REPLACING_ENTITY_REFERENCES);
|
||||
Boolean bo = (Boolean)propertyManager.getProperty(XMLInputFactory.IS_REPLACING_ENTITY_REFERENCES);
|
||||
fReplaceEntityReferences = bo.booleanValue();
|
||||
bo = (Boolean)propertyManager.getProperty(XMLInputFactoryImpl.IS_SUPPORTING_EXTERNAL_ENTITIES);
|
||||
bo = (Boolean)propertyManager.getProperty(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES);
|
||||
fSupportExternalEntities = bo.booleanValue();
|
||||
Boolean cdata = (Boolean)propertyManager.getProperty(Constants.ZEPHYR_PROPERTY_PREFIX + Constants.STAX_REPORT_CDATA_EVENT) ;
|
||||
if(cdata != null)
|
||||
|
@ -1,6 +1,5 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
* Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||
*/
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
@ -22,11 +21,11 @@
|
||||
package com.sun.org.apache.xerces.internal.impl ;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.Constants;
|
||||
import com.sun.org.apache.xerces.internal.impl.XMLEntityHandler;
|
||||
import com.sun.org.apache.xerces.internal.impl.io.ASCIIReader;
|
||||
import com.sun.org.apache.xerces.internal.impl.io.UCSReader;
|
||||
import com.sun.org.apache.xerces.internal.impl.io.UTF8Reader;
|
||||
import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter;
|
||||
import com.sun.org.apache.xerces.internal.impl.XMLEntityHandler;
|
||||
import com.sun.org.apache.xerces.internal.impl.validation.ValidationManager;
|
||||
import com.sun.org.apache.xerces.internal.util.*;
|
||||
import com.sun.org.apache.xerces.internal.util.URI;
|
||||
@ -54,6 +53,7 @@ import java.util.Locale;
|
||||
import java.util.Map;
|
||||
import java.util.Stack;
|
||||
import java.util.StringTokenizer;
|
||||
import javax.xml.stream.XMLInputFactory;
|
||||
|
||||
|
||||
/**
|
||||
@ -305,6 +305,11 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
||||
/** Property Manager. This is used from Stax */
|
||||
protected PropertyManager fPropertyManager ;
|
||||
|
||||
/** StAX properties */
|
||||
boolean fSupportDTD = true;
|
||||
boolean fReplaceEntityReferences = true;
|
||||
boolean fSupportExternalEntities = true;
|
||||
|
||||
/** used to restrict external access */
|
||||
protected String fAccessExternalDTD = EXTERNAL_ACCESS_DEFAULT;
|
||||
|
||||
@ -1136,7 +1141,8 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
||||
boolean parameter = entityName.startsWith("%");
|
||||
boolean general = !parameter;
|
||||
if (unparsed || (general && !fExternalGeneralEntities) ||
|
||||
(parameter && !fExternalParameterEntities)) {
|
||||
(parameter && !fExternalParameterEntities) ||
|
||||
!fSupportDTD || !fSupportExternalEntities) {
|
||||
|
||||
if (fEntityHandler != null) {
|
||||
fResourceIdentifier.clear();
|
||||
@ -1431,6 +1437,10 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
||||
fStaxEntityResolver = null;
|
||||
}
|
||||
|
||||
fSupportDTD = ((Boolean)propertyManager.getProperty(XMLInputFactory.SUPPORT_DTD)).booleanValue();
|
||||
fReplaceEntityReferences = ((Boolean)propertyManager.getProperty(XMLInputFactory.IS_REPLACING_ENTITY_REFERENCES)).booleanValue();
|
||||
fSupportExternalEntities = ((Boolean)propertyManager.getProperty(XMLInputFactory.IS_SUPPORTING_EXTERNAL_ENTITIES)).booleanValue();
|
||||
|
||||
// Zephyr feature ignore-external-dtd is the opposite of Xerces' load-external-dtd
|
||||
fLoadExternalDTD = !((Boolean)propertyManager.getProperty(Constants.ZEPHYR_PROPERTY_PREFIX + Constants.IGNORE_EXTERNAL_DTD)).booleanValue();
|
||||
|
||||
@ -1502,6 +1512,11 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
||||
fSecurityManager = (XMLSecurityManager)componentManager.getProperty(SECURITY_MANAGER, null);
|
||||
entityExpansionIndex = fSecurityManager.getIndex(Constants.JDK_ENTITY_EXPANSION_LIMIT);
|
||||
|
||||
//StAX Property
|
||||
fSupportDTD = true;
|
||||
fReplaceEntityReferences = true;
|
||||
fSupportExternalEntities = true;
|
||||
|
||||
// JAXP 1.5 feature
|
||||
XMLSecurityPropertyManager spm = (XMLSecurityPropertyManager) componentManager.getProperty(XML_SECURITY_PROPERTY_MANAGER, null);
|
||||
if (spm == null) {
|
||||
|
@ -3,60 +3,20 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* The Apache Software License, Version 1.1
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Copyright (c) 1999-2004 The Apache Software Foundation.
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* 3. The end-user documentation included with the redistribution,
|
||||
* if any, must include the following acknowledgment:
|
||||
* "This product includes software developed by the
|
||||
* Apache Software Foundation (http://www.apache.org/)."
|
||||
* Alternately, this acknowledgment may appear in the software itself,
|
||||
* if and wherever such third-party acknowledgments normally appear.
|
||||
*
|
||||
* 4. The names "Xerces" and "Apache Software Foundation" must
|
||||
* not be used to endorse or promote products derived from this
|
||||
* software without prior written permission. For written
|
||||
* permission, please contact apache@apache.org.
|
||||
*
|
||||
* 5. Products derived from this software may not be called "Apache",
|
||||
* nor may "Apache" appear in their name, without prior written
|
||||
* permission of the Apache Software Foundation.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
|
||||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
|
||||
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
* ====================================================================
|
||||
*
|
||||
* This software consists of voluntary contributions made by many
|
||||
* individuals on behalf of the Apache Software Foundation and was
|
||||
* originally based on software copyright (c) 1999, International
|
||||
* Business Machines, Inc., http://www.apache.org. For more
|
||||
* information on the Apache Software Foundation, please see
|
||||
* <http://www.apache.org/>.
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl;
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 1999-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -51,6 +52,7 @@ import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;
|
||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;
|
||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentFilter;
|
||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;
|
||||
import java.util.Iterator;
|
||||
|
||||
/**
|
||||
* The DTD validator. The validator implements a document
|
||||
@ -334,7 +336,7 @@ public class XMLDTDValidator
|
||||
// temporary variables
|
||||
|
||||
/** Temporary element declaration. */
|
||||
private XMLElementDecl fTempElementDecl = new XMLElementDecl();
|
||||
private final XMLElementDecl fTempElementDecl = new XMLElementDecl();
|
||||
|
||||
/** Temporary atribute declaration. */
|
||||
private final XMLAttributeDecl fTempAttDecl = new XMLAttributeDecl();
|
||||
@ -2020,12 +2022,14 @@ public class XMLDTDValidator
|
||||
// IDREF and IDREFS attr (V_IDREF0)
|
||||
//
|
||||
if (fPerformValidation) {
|
||||
String value = fValidationState.checkIDRefID();
|
||||
if (value != null) {
|
||||
fErrorReporter.reportError( XMLMessageFormatter.XML_DOMAIN,
|
||||
"MSG_ELEMENT_WITH_ID_REQUIRED",
|
||||
new Object[]{value},
|
||||
XMLErrorReporter.SEVERITY_ERROR );
|
||||
Iterator invIdRefs = fValidationState.checkIDRefID();
|
||||
if (invIdRefs != null) {
|
||||
while (invIdRefs.hasNext()) {
|
||||
fErrorReporter.reportError( XMLMessageFormatter.XML_DOMAIN,
|
||||
"MSG_ELEMENT_WITH_ID_REQUIRED",
|
||||
new Object[]{invIdRefs.next()},
|
||||
XMLErrorReporter.SEVERITY_ERROR );
|
||||
}
|
||||
}
|
||||
}
|
||||
return;
|
||||
|
@ -1,62 +1,21 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
* Copyright (c) 2006, 2009, Oracle and/or its affiliates. All rights reserved.
|
||||
*/
|
||||
/*
|
||||
* The Apache Software License, Version 1.1
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Copyright (c) 1999-2002 The Apache Software Foundation. All rights
|
||||
* reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* 3. The end-user documentation included with the redistribution,
|
||||
* if any, must include the following acknowledgment:
|
||||
* "This product includes software developed by the
|
||||
* Apache Software Foundation (http://www.apache.org/)."
|
||||
* Alternately, this acknowledgment may appear in the software itself,
|
||||
* if and wherever such third-party acknowledgments normally appear.
|
||||
*
|
||||
* 4. The names "Xerces" and "Apache Software Foundation" must
|
||||
* not be used to endorse or promote products derived from this
|
||||
* software without prior written permission. For written
|
||||
* permission, please contact apache@apache.org.
|
||||
*
|
||||
* 5. Products derived from this software may not be called "Apache",
|
||||
* nor may "Apache" appear in their name, without prior written
|
||||
* permission of the Apache Software Foundation.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
|
||||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
|
||||
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
* ====================================================================
|
||||
*
|
||||
* This software consists of voluntary contributions made by many
|
||||
* individuals on behalf of the Apache Software Foundation and was
|
||||
* originally based on software copyright (c) 1999, International
|
||||
* Business Machines, Inc., http://www.apache.org. For more
|
||||
* information on the Apache Software Foundation, please see
|
||||
* <http://www.apache.org/>.
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.dtd.models;
|
||||
@ -125,6 +84,14 @@ public abstract class CMNode
|
||||
fMaxStates = maxStates;
|
||||
}
|
||||
|
||||
public boolean isCompactedForUPA() {
|
||||
return fCompactedForUPA;
|
||||
}
|
||||
|
||||
public void setIsCompactUPAModel(boolean value) {
|
||||
fCompactedForUPA = value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Allows the user to set arbitrary data on this content model
|
||||
* node. This is used by the a{n,m} optimization that runs
|
||||
@ -181,10 +148,16 @@ public abstract class CMNode
|
||||
// init to to -1 so it will cause an error if its used without
|
||||
// being initialized.
|
||||
// -------------------------------------------------------------------
|
||||
private int fType;
|
||||
private CMStateSet fFirstPos = null;
|
||||
private CMStateSet fFollowPos = null;
|
||||
private CMStateSet fLastPos = null;
|
||||
private int fMaxStates = -1;
|
||||
private final int fType;
|
||||
private CMStateSet fFirstPos = null;
|
||||
private CMStateSet fFollowPos = null;
|
||||
private CMStateSet fLastPos = null;
|
||||
private int fMaxStates = -1;
|
||||
private Object fUserData = null;
|
||||
/*
|
||||
* This boolean is true if the model represented by the CMNode does not represent
|
||||
* the true model from the schema, but has had its min/maxOccurs modified for a
|
||||
* more compact representation (for purposes of UPA).
|
||||
*/
|
||||
private boolean fCompactedForUPA = false;
|
||||
};
|
||||
|
@ -1,3 +1,7 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
@ -17,8 +21,13 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.dv;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.ShortListImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.XSObjectListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.ShortList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObjectList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSValue;
|
||||
|
||||
/**
|
||||
* Class to get the information back after content is validated. This info
|
||||
@ -29,7 +38,7 @@ import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
* @author Neeraj Bajaj, Sun Microsystems, inc.
|
||||
*
|
||||
*/
|
||||
public class ValidatedInfo {
|
||||
public class ValidatedInfo implements XSValue {
|
||||
|
||||
/**
|
||||
* The normalized value of a string value
|
||||
@ -50,6 +59,11 @@ public class ValidatedInfo {
|
||||
*/
|
||||
public short actualValueType;
|
||||
|
||||
/**
|
||||
* The declared type of the value.
|
||||
*/
|
||||
public XSSimpleType actualType;
|
||||
|
||||
/**
|
||||
* If the type is a union type, then the member type which
|
||||
* actually validated the string value.
|
||||
@ -79,8 +93,11 @@ public class ValidatedInfo {
|
||||
public void reset() {
|
||||
this.normalizedValue = null;
|
||||
this.actualValue = null;
|
||||
this.actualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
this.actualType = null;
|
||||
this.memberType = null;
|
||||
this.memberTypes = null;
|
||||
this.itemValueTypes = null;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -88,10 +105,12 @@ public class ValidatedInfo {
|
||||
* value, use toString; otherwise, use the normalized value.
|
||||
*/
|
||||
public String stringValue() {
|
||||
if (actualValue == null)
|
||||
if (actualValue == null) {
|
||||
return normalizedValue;
|
||||
else
|
||||
}
|
||||
else {
|
||||
return actualValue.toString();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -149,4 +168,72 @@ public class ValidatedInfo {
|
||||
/** Other types. */
|
||||
return valueType;
|
||||
}
|
||||
|
||||
// XSValue methods
|
||||
|
||||
public Object getActualValue() {
|
||||
return actualValue;
|
||||
}
|
||||
|
||||
public short getActualValueType() {
|
||||
return actualValueType;
|
||||
}
|
||||
|
||||
public ShortList getListValueTypes() {
|
||||
return itemValueTypes == null ? ShortListImpl.EMPTY_LIST : itemValueTypes;
|
||||
}
|
||||
|
||||
public XSObjectList getMemberTypeDefinitions() {
|
||||
if (memberTypes == null) {
|
||||
return XSObjectListImpl.EMPTY_LIST;
|
||||
}
|
||||
return new XSObjectListImpl(memberTypes, memberTypes.length);
|
||||
}
|
||||
|
||||
public String getNormalizedValue() {
|
||||
return normalizedValue;
|
||||
}
|
||||
|
||||
public XSSimpleTypeDefinition getTypeDefinition() {
|
||||
return actualType;
|
||||
}
|
||||
|
||||
public XSSimpleTypeDefinition getMemberTypeDefinition() {
|
||||
return memberType;
|
||||
}
|
||||
|
||||
public void copyFrom(XSValue o) {
|
||||
if (o == null) {
|
||||
reset();
|
||||
}
|
||||
else if (o instanceof ValidatedInfo) {
|
||||
ValidatedInfo other = (ValidatedInfo)o;
|
||||
normalizedValue = other.normalizedValue;
|
||||
actualValue = other.actualValue;
|
||||
actualValueType = other.actualValueType;
|
||||
actualType = other.actualType;
|
||||
memberType = other.memberType;
|
||||
memberTypes = other.memberTypes;
|
||||
itemValueTypes = other.itemValueTypes;
|
||||
}
|
||||
else {
|
||||
normalizedValue = o.getNormalizedValue();
|
||||
actualValue = o.getActualValue();
|
||||
actualValueType = o.getActualValueType();
|
||||
actualType = (XSSimpleType)o.getTypeDefinition();
|
||||
memberType = (XSSimpleType)o.getMemberTypeDefinition();
|
||||
XSSimpleType realType = memberType == null ? actualType : memberType;
|
||||
if (realType != null && realType.getBuiltInKind() == XSConstants.LISTOFUNION_DT) {
|
||||
XSObjectList members = o.getMemberTypeDefinitions();
|
||||
memberTypes = new XSSimpleType[members.getLength()];
|
||||
for (int i = 0; i < members.getLength(); i++) {
|
||||
memberTypes[i] = (XSSimpleType)members.get(i);
|
||||
}
|
||||
}
|
||||
else {
|
||||
memberTypes = null;
|
||||
}
|
||||
itemValueTypes = o.getListValueTypes();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -17,6 +18,7 @@
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.dv.util;
|
||||
|
||||
import java.util.AbstractList;
|
||||
@ -102,4 +104,10 @@ public class ByteListImpl extends AbstractList implements ByteList {
|
||||
public int size() {
|
||||
return getLength();
|
||||
}
|
||||
|
||||
public byte[] toByteArray() {
|
||||
byte[] ret = new byte[data.length];
|
||||
System.arraycopy(data, 0, ret, 0, data.length);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,11 +21,6 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.dv.xs;
|
||||
|
||||
import java.util.AbstractList;
|
||||
import java.util.Locale;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.Vector;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.Constants;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.DatatypeException;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.InvalidDatatypeFacetException;
|
||||
@ -33,9 +29,10 @@ import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidationContext;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.XSFacets;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.XSSimpleType;
|
||||
import com.sun.org.apache.xerces.internal.impl.xpath.regex.RegularExpression;
|
||||
import com.sun.org.apache.xerces.internal.impl.xpath.regex.ParseException;
|
||||
import com.sun.org.apache.xerces.internal.impl.xpath.regex.RegularExpression;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.SchemaSymbols;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.ObjectListImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.ShortListImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.XSObjectListImpl;
|
||||
@ -48,10 +45,16 @@ import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSFacet;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSMultiValueFacet;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNamespaceItem;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObject;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObjectList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.datatypes.ObjectList;
|
||||
import java.math.BigInteger;
|
||||
import java.util.AbstractList;
|
||||
import java.util.Locale;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.Vector;
|
||||
import org.w3c.dom.TypeInfo;
|
||||
|
||||
/**
|
||||
@ -267,9 +270,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
private int fFractionDigits = -1;
|
||||
private Vector fPattern;
|
||||
private Vector fPatternStr;
|
||||
private Vector fEnumeration;
|
||||
private short[] fEnumerationType;
|
||||
private ShortList[] fEnumerationItemType; // used in case fenumerationType value is LIST or LISTOFUNION
|
||||
private ValidatedInfo[] fEnumeration;
|
||||
private int fEnumerationSize;
|
||||
private ShortList fEnumerationTypeList;
|
||||
private ObjectList fEnumerationItemTypeList;
|
||||
private StringList fLexicalPattern;
|
||||
@ -387,8 +389,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
fPattern = fBase.fPattern;
|
||||
fPatternStr = fBase.fPatternStr;
|
||||
fEnumeration = fBase.fEnumeration;
|
||||
fEnumerationType = fBase.fEnumerationType;
|
||||
fEnumerationItemType = fBase.fEnumerationItemType;
|
||||
fEnumerationSize = fBase.fEnumerationSize;
|
||||
fWhiteSpace = fBase.fWhiteSpace;
|
||||
fMaxExclusive = fBase.fMaxExclusive;
|
||||
fMaxInclusive = fBase.fMaxInclusive;
|
||||
@ -508,8 +509,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
fPattern = fBase.fPattern;
|
||||
fPatternStr = fBase.fPatternStr;
|
||||
fEnumeration = fBase.fEnumeration;
|
||||
fEnumerationType = fBase.fEnumerationType;
|
||||
fEnumerationItemType = fBase.fEnumerationItemType;
|
||||
fEnumerationSize = fBase.fEnumerationSize;
|
||||
fWhiteSpace = fBase.fWhiteSpace;
|
||||
fMaxExclusive = fBase.fMaxExclusive;
|
||||
fMaxInclusive = fBase.fMaxInclusive;
|
||||
@ -873,22 +873,20 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
if ((allowedFacet & FACET_ENUMERATION) == 0) {
|
||||
reportError("cos-applicable-facets", new Object[]{"enumeration", fTypeName});
|
||||
} else {
|
||||
fEnumeration = new Vector();
|
||||
Vector enumVals = facets.enumeration;
|
||||
fEnumerationType = new short[enumVals.size()];
|
||||
fEnumerationItemType = new ShortList[enumVals.size()];
|
||||
int size = enumVals.size();
|
||||
fEnumeration = new ValidatedInfo[size];
|
||||
Vector enumNSDecls = facets.enumNSDecls;
|
||||
ValidationContextImpl ctx = new ValidationContextImpl(context);
|
||||
enumerationAnnotations = facets.enumAnnotations;
|
||||
for (int i = 0; i < enumVals.size(); i++) {
|
||||
fEnumerationSize = 0;
|
||||
for (int i = 0; i < size; i++) {
|
||||
if (enumNSDecls != null)
|
||||
ctx.setNSContext((NamespaceContext)enumNSDecls.elementAt(i));
|
||||
try {
|
||||
ValidatedInfo info = getActualEnumValue((String)enumVals.elementAt(i), ctx, tempInfo);
|
||||
ValidatedInfo info = getActualEnumValue((String)enumVals.elementAt(i), ctx, null);
|
||||
// check 4.3.5.c0 must: enumeration values from the value space of base
|
||||
fEnumeration.addElement(info.actualValue);
|
||||
fEnumerationType[i] = info.actualValueType;
|
||||
fEnumerationItemType[i] = info.itemValueTypes;
|
||||
fEnumeration[fEnumerationSize++] = info;
|
||||
} catch (InvalidDatatypeValueException ide) {
|
||||
reportError("enumeration-valid-restriction", new Object[]{enumVals.elementAt(i), this.getBaseType().getName()});
|
||||
}
|
||||
@ -1478,6 +1476,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
if ((fFacetsDefined & FACET_ENUMERATION) == 0 && (fBase.fFacetsDefined & FACET_ENUMERATION) != 0) {
|
||||
fFacetsDefined |= FACET_ENUMERATION;
|
||||
fEnumeration = fBase.fEnumeration;
|
||||
fEnumerationSize = fBase.fEnumerationSize;
|
||||
enumerationAnnotations = fBase.enumerationAnnotations;
|
||||
}
|
||||
// inherit maxExclusive
|
||||
@ -1673,16 +1672,16 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
//enumeration
|
||||
if ( ((fFacetsDefined & FACET_ENUMERATION) != 0 ) ) {
|
||||
boolean present = false;
|
||||
final int enumSize = fEnumeration.size();
|
||||
final int enumSize = fEnumerationSize;
|
||||
final short primitiveType1 = convertToPrimitiveKind(type);
|
||||
for (int i = 0; i < enumSize; i++) {
|
||||
final short primitiveType2 = convertToPrimitiveKind(fEnumerationType[i]);
|
||||
final short primitiveType2 = convertToPrimitiveKind(fEnumeration[i].actualValueType);
|
||||
if ((primitiveType1 == primitiveType2 ||
|
||||
primitiveType1 == XSConstants.ANYSIMPLETYPE_DT && primitiveType2 == XSConstants.STRING_DT ||
|
||||
primitiveType1 == XSConstants.STRING_DT && primitiveType2 == XSConstants.ANYSIMPLETYPE_DT)
|
||||
&& fEnumeration.elementAt(i).equals(ob)) {
|
||||
&& fEnumeration[i].actualValue.equals(ob)) {
|
||||
if (primitiveType1 == XSConstants.LIST_DT || primitiveType1 == XSConstants.LISTOFUNION_DT) {
|
||||
ShortList enumItemType = fEnumerationItemType[i];
|
||||
ShortList enumItemType = fEnumeration[i].itemValueTypes;
|
||||
final int typeList1Length = itemType != null ? itemType.getLength() : 0;
|
||||
final int typeList2Length = enumItemType != null ? enumItemType.getLength() : 0;
|
||||
if (typeList1Length == typeList2Length) {
|
||||
@ -1711,8 +1710,10 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
}
|
||||
}
|
||||
if(!present){
|
||||
StringBuffer sb = new StringBuffer();
|
||||
appendEnumString(sb);
|
||||
throw new InvalidDatatypeValueException("cvc-enumeration-valid",
|
||||
new Object [] {content, fEnumeration.toString()});
|
||||
new Object [] {content, sb.toString()});
|
||||
}
|
||||
}
|
||||
|
||||
@ -1827,12 +1828,6 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
nvalue = content.toString();
|
||||
}
|
||||
if ( (fFacetsDefined & FACET_PATTERN ) != 0 ) {
|
||||
if (fPattern.size()==0 && nvalue.length()>0) {
|
||||
throw new InvalidDatatypeValueException("cvc-pattern-valid",
|
||||
new Object[]{content,
|
||||
"(empty string)",
|
||||
fTypeName});
|
||||
}
|
||||
RegularExpression regex;
|
||||
for (int idx = fPattern.size()-1; idx >= 0; idx--) {
|
||||
regex = (RegularExpression)fPattern.elementAt(idx);
|
||||
@ -1840,6 +1835,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
throw new InvalidDatatypeValueException("cvc-pattern-valid",
|
||||
new Object[]{content,
|
||||
fPatternStr.elementAt(idx),
|
||||
|
||||
fTypeName});
|
||||
}
|
||||
}
|
||||
@ -1873,6 +1869,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
Object avalue = fDVs[fValidationDV].getActualValue(nvalue, context);
|
||||
validatedInfo.actualValue = avalue;
|
||||
validatedInfo.actualValueType = fBuiltInKind;
|
||||
validatedInfo.actualType = this;
|
||||
|
||||
return avalue;
|
||||
|
||||
@ -1910,6 +1907,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
validatedInfo.memberTypes = memberTypes;
|
||||
validatedInfo.itemValueTypes = new ShortListImpl(itemTypes, itemTypes.length);
|
||||
validatedInfo.normalizedValue = nvalue;
|
||||
// Need to set it here or it will become the item type
|
||||
validatedInfo.actualType = this;
|
||||
|
||||
return v;
|
||||
|
||||
@ -1929,6 +1928,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
fMemberTypes[i].checkFacets(validatedInfo);
|
||||
}
|
||||
validatedInfo.memberType = fMemberTypes[i];
|
||||
// Need to set it here or it will become the member type
|
||||
validatedInfo.actualType = this;
|
||||
return aValue;
|
||||
} catch(InvalidDatatypeValueException invalidValue) {
|
||||
}
|
||||
@ -1946,14 +1947,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
}
|
||||
typesBuffer.append(decl.fTypeName);
|
||||
if(decl.fEnumeration != null) {
|
||||
Vector v = decl.fEnumeration;
|
||||
typesBuffer.append(" : [");
|
||||
for(int j = 0;j < v.size(); j++) {
|
||||
if(j != 0)
|
||||
typesBuffer.append(',');
|
||||
typesBuffer.append(v.elementAt(j));
|
||||
}
|
||||
typesBuffer.append(']');
|
||||
typesBuffer.append(" : ");
|
||||
decl.appendEnumString(typesBuffer);
|
||||
}
|
||||
}
|
||||
throw new InvalidDatatypeValueException("cvc-datatype-valid.1.2.3",
|
||||
@ -2245,10 +2240,10 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
if (fLexicalEnumeration == null){
|
||||
if (fEnumeration == null)
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
int size = fEnumeration.size();
|
||||
int size = fEnumerationSize;
|
||||
String[] strs = new String[size];
|
||||
for (int i = 0; i < size; i++)
|
||||
strs[i] = fEnumeration.elementAt(i).toString();
|
||||
strs[i] = fEnumeration[i].normalizedValue;
|
||||
fLexicalEnumeration = new StringListImpl(strs, size);
|
||||
}
|
||||
return fLexicalEnumeration;
|
||||
@ -2262,16 +2257,24 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
if (fActualEnumeration == null) {
|
||||
fActualEnumeration = new AbstractObjectList() {
|
||||
public int getLength() {
|
||||
return (fEnumeration != null) ? fEnumeration.size() : 0;
|
||||
return (fEnumeration != null) ? fEnumerationSize : 0;
|
||||
}
|
||||
public boolean contains(Object item) {
|
||||
return (fEnumeration != null && fEnumeration.contains(item));
|
||||
if (fEnumeration == null) {
|
||||
return false;
|
||||
}
|
||||
for (int i = 0; i < fEnumerationSize; i++) {
|
||||
if (fEnumeration[i].getActualValue().equals(item)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
public Object item(int index) {
|
||||
if (index < 0 || index >= getLength()) {
|
||||
return null;
|
||||
}
|
||||
return fEnumeration.elementAt(index);
|
||||
return fEnumeration[index].getActualValue();
|
||||
}
|
||||
};
|
||||
}
|
||||
@ -2284,17 +2287,18 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
*/
|
||||
public ObjectList getEnumerationItemTypeList() {
|
||||
if (fEnumerationItemTypeList == null) {
|
||||
if(fEnumerationItemType == null)
|
||||
if (fEnumeration == null) {
|
||||
return null;
|
||||
}
|
||||
fEnumerationItemTypeList = new AbstractObjectList() {
|
||||
public int getLength() {
|
||||
return (fEnumerationItemType != null) ? fEnumerationItemType.length : 0;
|
||||
return (fEnumeration != null) ? fEnumerationSize : 0;
|
||||
}
|
||||
public boolean contains(Object item) {
|
||||
if(fEnumerationItemType == null || !(item instanceof ShortList))
|
||||
if (fEnumeration == null || !(item instanceof ShortList))
|
||||
return false;
|
||||
for(int i = 0;i < fEnumerationItemType.length; i++)
|
||||
if(fEnumerationItemType[i] == item)
|
||||
for (int i = 0;i < fEnumerationSize; i++)
|
||||
if (fEnumeration[i].itemValueTypes == item)
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
@ -2302,7 +2306,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
if (index < 0 || index >= getLength()) {
|
||||
return null;
|
||||
}
|
||||
return fEnumerationItemType[index];
|
||||
return fEnumeration[index].itemValueTypes;
|
||||
}
|
||||
};
|
||||
}
|
||||
@ -2311,10 +2315,14 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
|
||||
public ShortList getEnumerationTypeList() {
|
||||
if (fEnumerationTypeList == null) {
|
||||
if (fEnumerationType == null) {
|
||||
if (fEnumeration == null) {
|
||||
return ShortListImpl.EMPTY_LIST;
|
||||
}
|
||||
fEnumerationTypeList = new ShortListImpl (fEnumerationType, fEnumerationType.length);
|
||||
short[] list = new short[fEnumerationSize];
|
||||
for (int i = 0; i < fEnumerationSize; i++) {
|
||||
list[i] = fEnumeration[i].actualValueType;
|
||||
}
|
||||
fEnumerationTypeList = new ShortListImpl(list, fEnumerationSize);
|
||||
}
|
||||
return fEnumerationTypeList;
|
||||
}
|
||||
@ -2978,10 +2986,11 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
fPattern = null;
|
||||
fPatternStr = null;
|
||||
fEnumeration = null;
|
||||
fEnumerationType = null;
|
||||
fEnumerationItemType = null;
|
||||
fLexicalPattern = null;
|
||||
fLexicalEnumeration = null;
|
||||
fActualEnumeration = null;
|
||||
fEnumerationTypeList = null;
|
||||
fEnumerationItemTypeList = null;
|
||||
fMaxInclusive = null;
|
||||
fMaxExclusive = null;
|
||||
fMinExclusive = null;
|
||||
@ -3043,6 +3052,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_WHITESPACE,
|
||||
WS_FACET_STRING[fWhiteSpace],
|
||||
0,
|
||||
null,
|
||||
(fFixedFacet & FACET_WHITESPACE) != 0,
|
||||
whiteSpaceAnnotation);
|
||||
count++;
|
||||
@ -3052,6 +3063,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_LENGTH,
|
||||
Integer.toString(fLength),
|
||||
fLength,
|
||||
null,
|
||||
(fFixedFacet & FACET_LENGTH) != 0,
|
||||
lengthAnnotation);
|
||||
count++;
|
||||
@ -3061,6 +3074,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MINLENGTH,
|
||||
Integer.toString(fMinLength),
|
||||
fMinLength,
|
||||
null,
|
||||
(fFixedFacet & FACET_MINLENGTH) != 0,
|
||||
minLengthAnnotation);
|
||||
count++;
|
||||
@ -3070,6 +3085,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MAXLENGTH,
|
||||
Integer.toString(fMaxLength),
|
||||
fMaxLength,
|
||||
null,
|
||||
(fFixedFacet & FACET_MAXLENGTH) != 0,
|
||||
maxLengthAnnotation);
|
||||
count++;
|
||||
@ -3079,6 +3096,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_TOTALDIGITS,
|
||||
Integer.toString(fTotalDigits),
|
||||
fTotalDigits,
|
||||
null,
|
||||
(fFixedFacet & FACET_TOTALDIGITS) != 0,
|
||||
totalDigitsAnnotation);
|
||||
count++;
|
||||
@ -3088,6 +3107,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_FRACTIONDIGITS,
|
||||
"0",
|
||||
0,
|
||||
null,
|
||||
true,
|
||||
fractionDigitsAnnotation);
|
||||
count++;
|
||||
@ -3097,6 +3118,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_FRACTIONDIGITS,
|
||||
Integer.toString(fFractionDigits),
|
||||
fFractionDigits,
|
||||
null,
|
||||
(fFixedFacet & FACET_FRACTIONDIGITS) != 0,
|
||||
fractionDigitsAnnotation);
|
||||
count++;
|
||||
@ -3106,6 +3129,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MAXINCLUSIVE,
|
||||
fMaxInclusive.toString(),
|
||||
0,
|
||||
fMaxInclusive,
|
||||
(fFixedFacet & FACET_MAXINCLUSIVE) != 0,
|
||||
maxInclusiveAnnotation);
|
||||
count++;
|
||||
@ -3115,6 +3140,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MAXEXCLUSIVE,
|
||||
fMaxExclusive.toString(),
|
||||
0,
|
||||
fMaxExclusive,
|
||||
(fFixedFacet & FACET_MAXEXCLUSIVE) != 0,
|
||||
maxExclusiveAnnotation);
|
||||
count++;
|
||||
@ -3124,6 +3151,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MINEXCLUSIVE,
|
||||
fMinExclusive.toString(),
|
||||
0,
|
||||
fMinExclusive,
|
||||
(fFixedFacet & FACET_MINEXCLUSIVE) != 0,
|
||||
minExclusiveAnnotation);
|
||||
count++;
|
||||
@ -3133,6 +3162,8 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSFacetImpl(
|
||||
FACET_MININCLUSIVE,
|
||||
fMinInclusive.toString(),
|
||||
0,
|
||||
fMinInclusive,
|
||||
(fFixedFacet & FACET_MININCLUSIVE) != 0,
|
||||
minInclusiveAnnotation);
|
||||
count++;
|
||||
@ -3142,6 +3173,28 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
return (fFacets != null) ? fFacets : XSObjectListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
public XSObject getFacet(int facetType) {
|
||||
if (facetType == FACET_ENUMERATION || facetType == FACET_PATTERN) {
|
||||
XSObjectList list = getMultiValueFacets();
|
||||
for (int i = 0; i < list.getLength(); i++) {
|
||||
XSMultiValueFacet f = (XSMultiValueFacet)list.item(i);
|
||||
if (f.getFacetKind() == facetType) {
|
||||
return f;
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
XSObjectList list = getFacets();
|
||||
for (int i = 0; i < list.getLength(); i++) {
|
||||
XSFacet f = (XSFacet)list.item(i);
|
||||
if (f.getFacetKind() == facetType) {
|
||||
return f;
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* A list of enumeration and pattern constraining facets if it exists,
|
||||
* otherwise an empty <code>XSObjectList</code>.
|
||||
@ -3162,6 +3215,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSMVFacetImpl(
|
||||
FACET_PATTERN,
|
||||
this.getLexicalPattern(),
|
||||
null,
|
||||
patternAnnotations);
|
||||
count++;
|
||||
}
|
||||
@ -3170,6 +3224,7 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
new XSMVFacetImpl(
|
||||
FACET_ENUMERATION,
|
||||
this.getLexicalEnumeration(),
|
||||
new ObjectListImpl(fEnumeration, fEnumerationSize),
|
||||
enumerationAnnotations);
|
||||
count++;
|
||||
}
|
||||
@ -3201,13 +3256,17 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
|
||||
private static final class XSFacetImpl implements XSFacet {
|
||||
final short kind;
|
||||
final String value;
|
||||
final String svalue;
|
||||
final int ivalue;
|
||||
Object avalue;
|
||||
final boolean fixed;
|
||||
final XSObjectList annotations;
|
||||
|
||||
public XSFacetImpl(short kind, String value, boolean fixed, XSAnnotation annotation) {
|
||||
public XSFacetImpl(short kind, String svalue, int ivalue, Object avalue, boolean fixed, XSAnnotation annotation) {
|
||||
this.kind = kind;
|
||||
this.value = value;
|
||||
this.svalue = svalue;
|
||||
this.ivalue = ivalue;
|
||||
this.avalue = avalue;
|
||||
this.fixed = fixed;
|
||||
|
||||
if (annotation != null) {
|
||||
@ -3254,7 +3313,24 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.XSFacet#getLexicalFacetValue()
|
||||
*/
|
||||
public String getLexicalFacetValue() {
|
||||
return value;
|
||||
return svalue;
|
||||
}
|
||||
|
||||
public Object getActualFacetValue() {
|
||||
if (avalue == null) {
|
||||
if (kind == FACET_WHITESPACE) {
|
||||
avalue = svalue;
|
||||
}
|
||||
else {
|
||||
// Must a facet with an integer value. Use BigInteger.
|
||||
avalue = BigInteger.valueOf(ivalue);
|
||||
}
|
||||
}
|
||||
return avalue;
|
||||
}
|
||||
|
||||
public int getIntFacetValue() {
|
||||
return ivalue;
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
@ -3298,11 +3374,13 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
private static final class XSMVFacetImpl implements XSMultiValueFacet {
|
||||
final short kind;
|
||||
final XSObjectList annotations;
|
||||
final StringList values;
|
||||
final StringList svalues;
|
||||
final ObjectList avalues;
|
||||
|
||||
public XSMVFacetImpl(short kind, StringList values, XSObjectList annotations) {
|
||||
public XSMVFacetImpl(short kind, StringList svalues, ObjectList avalues, XSObjectList annotations) {
|
||||
this.kind = kind;
|
||||
this.values = values;
|
||||
this.svalues = svalues;
|
||||
this.avalues = avalues;
|
||||
this.annotations = (annotations != null) ? annotations : XSObjectListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
@ -3324,7 +3402,11 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.XSMultiValueFacet#getLexicalFacetValues()
|
||||
*/
|
||||
public StringList getLexicalFacetValues() {
|
||||
return values;
|
||||
return svalues;
|
||||
}
|
||||
|
||||
public ObjectList getEnumerationValues() {
|
||||
return avalues;
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
@ -3394,4 +3476,14 @@ public class XSSimpleTypeDecl implements XSSimpleType, TypeInfo {
|
||||
return valueType;
|
||||
}
|
||||
|
||||
private void appendEnumString(StringBuffer sb) {
|
||||
sb.append('[');
|
||||
for (int i = 0; i < fEnumerationSize; i++) {
|
||||
if (i != 0) {
|
||||
sb.append(", ");
|
||||
}
|
||||
sb.append(fEnumeration[i].actualValue);
|
||||
}
|
||||
sb.append(']');
|
||||
}
|
||||
} // class XSSimpleTypeDecl
|
||||
|
@ -30,6 +30,7 @@ import com.sun.org.apache.xerces.internal.impl.dv.XSFacets;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.XSSimpleType;
|
||||
import com.sun.org.apache.xerces.internal.xs.StringList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNamespaceItem;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObject;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObjectList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition;
|
||||
@ -76,6 +77,10 @@ public class XSSimpleTypeDelegate
|
||||
return type.getFacets();
|
||||
}
|
||||
|
||||
public XSObject getFacet(int facetType) {
|
||||
return type.getFacet(facetType);
|
||||
}
|
||||
|
||||
public boolean getFinite() {
|
||||
return type.getFinite();
|
||||
}
|
||||
|
@ -41,7 +41,13 @@
|
||||
cvc-complex-type.2.4.b = cvc-complex-type.2.4.b: The content of element ''{0}'' is not complete. One of ''{1}'' is expected.
|
||||
cvc-complex-type.2.4.c = cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration can be found for element ''{0}''.
|
||||
cvc-complex-type.2.4.d = cvc-complex-type.2.4.d: Invalid content was found starting with element ''{0}''. No child element is expected at this point.
|
||||
cvc-complex-type.2.4.e = cvc-complex-type.2.4.d: Invalid content was found starting with element ''{0}''. No child element ''{1}'' is expected at this point.
|
||||
cvc-complex-type.2.4.d.1 = cvc-complex-type.2.4.d: Invalid content was found starting with element ''{0}''. No child element ''{1}'' is expected at this point.
|
||||
cvc-complex-type.2.4.e = cvc-complex-type.2.4.e: ''{0}'' can occur a maximum of ''{2}'' times in the current sequence. This limit was exceeded. At this point one of ''{1}'' is expected.
|
||||
cvc-complex-type.2.4.f = cvc-complex-type.2.4.f: ''{0}'' can occur a maximum of ''{1}'' times in the current sequence. This limit was exceeded. No child element is expected at this point.
|
||||
cvc-complex-type.2.4.g = cvc-complex-type.2.4.g: Invalid content was found starting with element ''{0}''. ''{1}'' is expected to occur a minimum of ''{2}'' times in the current sequence. One more instance is required to satisfy this constraint.
|
||||
cvc-complex-type.2.4.h = cvc-complex-type.2.4.h: Invalid content was found starting with element ''{0}''. ''{1}'' is expected to occur a minimum of ''{2}'' times in the current sequence. ''{3}'' more instances are required to satisfy this constraint.
|
||||
cvc-complex-type.2.4.i = cvc-complex-type.2.4.i: The content of element ''{0}'' is not complete. ''{1}'' is expected to occur a minimum of ''{2}'' times. One more instance is required to satisfy this constraint.
|
||||
cvc-complex-type.2.4.j = cvc-complex-type.2.4.j: The content of element ''{0}'' is not complete. ''{1}'' is expected to occur a minimum of ''{2}'' times. ''{3}'' more instances are required to satisfy this constraint.
|
||||
cvc-complex-type.3.1 = cvc-complex-type.3.1: Value ''{2}'' of attribute ''{1}'' of element ''{0}'' is not valid with respect to the corresponding attribute use. Attribute ''{1}'' has a fixed value of ''{3}''.
|
||||
cvc-complex-type.3.2.1 = cvc-complex-type.3.2.1: Element ''{0}'' does not have an attribute wildcard for attribute ''{1}''.
|
||||
cvc-complex-type.3.2.2 = cvc-complex-type.3.2.2: Attribute ''{1}'' is not allowed to appear in element ''{0}''.
|
||||
@ -51,7 +57,8 @@
|
||||
cvc-datatype-valid.1.2.1 = cvc-datatype-valid.1.2.1: ''{0}'' is not a valid value for ''{1}''.
|
||||
cvc-datatype-valid.1.2.2 = cvc-datatype-valid.1.2.2: ''{0}'' is not a valid value of list type ''{1}''.
|
||||
cvc-datatype-valid.1.2.3 = cvc-datatype-valid.1.2.3: ''{0}'' is not a valid value of union type ''{1}''.
|
||||
cvc-elt.1 = cvc-elt.1: Cannot find the declaration of element ''{0}''.
|
||||
cvc-elt.1.a = cvc-elt.1.a: Cannot find the declaration of element ''{0}''.
|
||||
cvc-elt.1.b = cvc-elt.1.b: The name of the element does not match the name of the element declaration. Saw ''{0}''. Expected ''{1}''.
|
||||
cvc-elt.2 = cvc-elt.2: The value of '{'abstract'}' in the element declaration for ''{0}'' must be false.
|
||||
cvc-elt.3.1 = cvc-elt.3.1: Attribute ''{1}'' must not appear on element ''{0}'', because the '{'nillable'}' property of ''{0}'' is false.
|
||||
cvc-elt.3.2.1 = cvc-elt.3.2.1: Element ''{0}'' cannot have character or element information [children], because ''{1}'' is specified.
|
||||
@ -289,3 +296,10 @@
|
||||
TargetNamespace.2 = TargetNamespace.2: Expecting no namespace, but the schema document has a target namespace of ''{1}''.
|
||||
UndeclaredEntity = UndeclaredEntity: Entity ''{0}'' is not declared.
|
||||
UndeclaredPrefix = UndeclaredPrefix: Cannot resolve ''{0}'' as a QName: the prefix ''{1}'' is not declared.
|
||||
|
||||
|
||||
# JAXP 1.2 schema source property errors
|
||||
|
||||
jaxp12-schema-source-type.1 = The ''http://java.sun.com/xml/jaxp/properties/schemaSource'' property cannot have a value of type ''{0}''. Possible types of the value supported are String, File, InputStream, InputSource or an array of these types.
|
||||
jaxp12-schema-source-type.2 = The ''http://java.sun.com/xml/jaxp/properties/schemaSource'' property cannot have an array value of type ''{0}''. Possible types of the array supported are Object, String, File, InputStream and InputSource.
|
||||
jaxp12-schema-source-ns = When using an array of Objects as the value of the 'http://java.sun.com/xml/jaxp/properties/schemaSource' property, it is illegal to have two schemas that share the same target namespace.
|
||||
|
@ -1,9 +1,14 @@
|
||||
/*
|
||||
* Copyright 2006 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -16,6 +21,8 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.validation;
|
||||
|
||||
import java.util.Iterator;
|
||||
|
||||
/**
|
||||
* <p>An extension of ValidationState which can be configured to turn
|
||||
* off checking for ID/IDREF errors and unparsed entity errors.</p>
|
||||
@ -49,7 +56,7 @@ public final class ConfigurableValidationState extends ValidationState {
|
||||
|
||||
/**
|
||||
* Turns checking for ID/IDREF errors on and off.
|
||||
* @param setting: true to turn on error checking
|
||||
* @param setting true to turn on error checking,
|
||||
* false to turn off error checking
|
||||
*/
|
||||
public void setIdIdrefChecking(boolean setting) {
|
||||
@ -58,7 +65,7 @@ public final class ConfigurableValidationState extends ValidationState {
|
||||
|
||||
/**
|
||||
* Turns checking for unparsed entity errors on and off.
|
||||
* @param setting: true to turn on error checking
|
||||
* @param setting true to turn on error checking,
|
||||
* false to turn off error checking
|
||||
*/
|
||||
public void setUnparsedEntityChecking(boolean setting) {
|
||||
@ -70,7 +77,7 @@ public final class ConfigurableValidationState extends ValidationState {
|
||||
* @return null, if ID/IDREF checking is turned off
|
||||
* otherwise, returns the value of the super implementation
|
||||
*/
|
||||
public String checkIDRefID() {
|
||||
public Iterator checkIDRefID() {
|
||||
return (fIdIdrefChecking) ? super.checkIDRefID() : null;
|
||||
}
|
||||
|
||||
@ -103,7 +110,7 @@ public final class ConfigurableValidationState extends ValidationState {
|
||||
|
||||
/**
|
||||
* Adds the ID, if ID/IDREF checking is enabled.
|
||||
* @param the ID to add
|
||||
* @param name the ID to add
|
||||
*/
|
||||
public void addId(String name) {
|
||||
if (fIdIdrefChecking) {
|
||||
@ -113,7 +120,7 @@ public final class ConfigurableValidationState extends ValidationState {
|
||||
|
||||
/**
|
||||
* Adds the IDREF, if ID/IDREF checking is enabled.
|
||||
* @param the IDREF to add
|
||||
* @param name the IDREF to add
|
||||
*/
|
||||
public void addIdRef(String name) {
|
||||
if (fIdIdrefChecking) {
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001, 2002,2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,11 +21,12 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.validation;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidationContext;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
||||
import com.sun.org.apache.xerces.internal.xni.NamespaceContext;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.Locale;
|
||||
|
||||
/**
|
||||
@ -86,25 +88,24 @@ public class ValidationState implements ValidationContext {
|
||||
|
||||
/**
|
||||
* return null if all IDREF values have a corresponding ID value;
|
||||
* otherwise return the first IDREF value without a matching ID value.
|
||||
* otherwise return an iterator for all the IDREF values without
|
||||
* a matching ID value.
|
||||
*/
|
||||
public String checkIDRefID () {
|
||||
if (fIdList == null) {
|
||||
if (fIdRefList != null) {
|
||||
return fIdRefList.get(0);
|
||||
}
|
||||
}
|
||||
|
||||
public Iterator checkIDRefID () {
|
||||
HashSet missingIDs = null;
|
||||
if (fIdRefList != null) {
|
||||
String key;
|
||||
for (int i = 0; i < fIdRefList.size(); i++) {
|
||||
key = fIdRefList.get(i);
|
||||
if (!fIdList.contains(key)) {
|
||||
return key;
|
||||
if (fIdList == null || !fIdList.contains(key)) {
|
||||
if (missingIDs == null) {
|
||||
missingIDs = new HashSet();
|
||||
}
|
||||
missingIDs.add(key);
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
return (missingIDs != null) ? missingIDs.iterator() : null;
|
||||
}
|
||||
|
||||
public void reset () {
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2000-2002,2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,14 +21,17 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.xs;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.AttributePSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.ItemPSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.ShortList;
|
||||
import com.sun.org.apache.xerces.internal.xs.StringList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSAttributeDeclaration;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.AttributePSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSValue;
|
||||
|
||||
/**
|
||||
* Attribute PSV infoset augmentations implementation.
|
||||
@ -49,20 +53,8 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
* value in the original document, this is false; otherwise, it is true */
|
||||
protected boolean fSpecified = false;
|
||||
|
||||
/** schema normalized value property */
|
||||
protected String fNormalizedValue = null;
|
||||
|
||||
/** schema actual value */
|
||||
protected Object fActualValue = null;
|
||||
|
||||
/** schema actual value type */
|
||||
protected short fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
|
||||
/** actual value types if the value is a list */
|
||||
protected ShortList fItemValueTypes = null;
|
||||
|
||||
/** member type definition against which attribute was validated */
|
||||
protected XSSimpleTypeDefinition fMemberType = null;
|
||||
/** Schema value */
|
||||
protected ValidatedInfo fValue = new ValidatedInfo();
|
||||
|
||||
/** validation attempted: none, partial, full */
|
||||
protected short fValidationAttempted = AttributePSVI.VALIDATION_NONE;
|
||||
@ -70,16 +62,67 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
/** validity: valid, invalid, unknown */
|
||||
protected short fValidity = AttributePSVI.VALIDITY_NOTKNOWN;
|
||||
|
||||
/** error codes */
|
||||
protected String[] fErrorCodes = null;
|
||||
/** error codes and error messages */
|
||||
protected String[] fErrors = null;
|
||||
|
||||
/** validation context: could be QName or XPath expression*/
|
||||
protected String fValidationContext = null;
|
||||
|
||||
/** true if this object is immutable **/
|
||||
protected boolean fIsConstant;
|
||||
|
||||
public AttributePSVImpl() {}
|
||||
|
||||
public AttributePSVImpl(boolean isConstant, AttributePSVI attrPSVI) {
|
||||
fDeclaration = attrPSVI.getAttributeDeclaration();
|
||||
fTypeDecl = attrPSVI.getTypeDefinition();
|
||||
fSpecified = attrPSVI.getIsSchemaSpecified();
|
||||
fValue.copyFrom(attrPSVI.getSchemaValue());
|
||||
fValidationAttempted = attrPSVI.getValidationAttempted();
|
||||
fValidity = attrPSVI.getValidity();
|
||||
if (attrPSVI instanceof AttributePSVImpl) {
|
||||
final AttributePSVImpl attrPSVIImpl = (AttributePSVImpl) attrPSVI;
|
||||
fErrors = (attrPSVIImpl.fErrors != null) ?
|
||||
(String[]) attrPSVIImpl.fErrors.clone() : null;
|
||||
}
|
||||
else {
|
||||
final StringList errorCodes = attrPSVI.getErrorCodes();
|
||||
final int length = errorCodes.getLength();
|
||||
if (length > 0) {
|
||||
final StringList errorMessages = attrPSVI.getErrorMessages();
|
||||
final String[] errors = new String[length << 1];
|
||||
for (int i = 0, j = 0; i < length; ++i) {
|
||||
errors[j++] = errorCodes.item(i);
|
||||
errors[j++] = errorMessages.item(i);
|
||||
}
|
||||
fErrors = errors;
|
||||
}
|
||||
}
|
||||
fValidationContext = attrPSVI.getValidationContext();
|
||||
fIsConstant = isConstant;
|
||||
}
|
||||
|
||||
//
|
||||
// AttributePSVI methods
|
||||
//
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#constant()
|
||||
*/
|
||||
public ItemPSVI constant() {
|
||||
if (isConstant()) {
|
||||
return this;
|
||||
}
|
||||
return new AttributePSVImpl(true, this);
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#isConstant()
|
||||
*/
|
||||
public boolean isConstant() {
|
||||
return fIsConstant;
|
||||
}
|
||||
|
||||
/**
|
||||
* [schema default]
|
||||
*
|
||||
@ -98,7 +141,7 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
* @return the normalized value of this item after validation
|
||||
*/
|
||||
public String getSchemaNormalizedValue() {
|
||||
return fNormalizedValue;
|
||||
return fValue.getNormalizedValue();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -139,9 +182,23 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
* @return list of error codes
|
||||
*/
|
||||
public StringList getErrorCodes() {
|
||||
if (fErrorCodes == null)
|
||||
return null;
|
||||
return new StringListImpl(fErrorCodes, fErrorCodes.length);
|
||||
if (fErrors == null || fErrors.length == 0) {
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
return new PSVIErrorList(fErrors, true);
|
||||
}
|
||||
|
||||
/**
|
||||
* A list of error messages generated from the validation attempt or
|
||||
* an empty <code>StringList</code> if no errors occurred during the
|
||||
* validation attempt. The indices of error messages in this list are
|
||||
* aligned with those in the <code>[schema error code]</code> list.
|
||||
*/
|
||||
public StringList getErrorMessages() {
|
||||
if (fErrors == null || fErrors.length == 0) {
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
return new PSVIErrorList(fErrors, false);
|
||||
}
|
||||
|
||||
// This is the only information we can provide in a pipeline.
|
||||
@ -168,7 +225,7 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
* @return a simple type declaration
|
||||
*/
|
||||
public XSSimpleTypeDefinition getMemberTypeDefinition() {
|
||||
return fMemberType;
|
||||
return fValue.getMemberTypeDefinition();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -185,38 +242,41 @@ public class AttributePSVImpl implements AttributePSVI {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValue()
|
||||
*/
|
||||
public Object getActualNormalizedValue() {
|
||||
return this.fActualValue;
|
||||
return fValue.getActualValue();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValueType()
|
||||
*/
|
||||
public short getActualNormalizedValueType() {
|
||||
return this.fActualValueType;
|
||||
return fValue.getActualValueType();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getItemValueTypes()
|
||||
*/
|
||||
public ShortList getItemValueTypes() {
|
||||
return this.fItemValueTypes;
|
||||
return fValue.getListValueTypes();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getSchemaValue()
|
||||
*/
|
||||
public XSValue getSchemaValue() {
|
||||
return fValue;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reset()
|
||||
*/
|
||||
public void reset() {
|
||||
fNormalizedValue = null;
|
||||
fActualValue = null;
|
||||
fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
fItemValueTypes = null;
|
||||
fValue.reset();
|
||||
fDeclaration = null;
|
||||
fTypeDecl = null;
|
||||
fSpecified = false;
|
||||
fMemberType = null;
|
||||
fValidationAttempted = AttributePSVI.VALIDATION_NONE;
|
||||
fValidity = AttributePSVI.VALIDITY_NOTKNOWN;
|
||||
fErrorCodes = null;
|
||||
fErrors = null;
|
||||
fValidationContext = null;
|
||||
}
|
||||
}
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2000-2002,2004,2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,16 +21,19 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.xs;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.ElementPSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.ItemPSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.ShortList;
|
||||
import com.sun.org.apache.xerces.internal.xs.StringList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSElementDeclaration;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSModel;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNotationDeclaration;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.impl.xs.util.StringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.xs.ElementPSVI;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSValue;
|
||||
|
||||
/**
|
||||
* Element PSV infoset augmentations implementation.
|
||||
@ -61,32 +65,20 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
*/
|
||||
protected boolean fSpecified = false;
|
||||
|
||||
/** schema normalized value property */
|
||||
protected String fNormalizedValue = null;
|
||||
|
||||
/** schema actual value */
|
||||
protected Object fActualValue = null;
|
||||
|
||||
/** schema actual value type */
|
||||
protected short fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
|
||||
/** actual value types if the value is a list */
|
||||
protected ShortList fItemValueTypes = null;
|
||||
/** Schema value */
|
||||
protected ValidatedInfo fValue = new ValidatedInfo();
|
||||
|
||||
/** http://www.w3.org/TR/xmlschema-1/#e-notation*/
|
||||
protected XSNotationDeclaration fNotation = null;
|
||||
|
||||
/** member type definition against which element was validated */
|
||||
protected XSSimpleTypeDefinition fMemberType = null;
|
||||
|
||||
/** validation attempted: none, partial, full */
|
||||
protected short fValidationAttempted = ElementPSVI.VALIDATION_NONE;
|
||||
|
||||
/** validity: valid, invalid, unknown */
|
||||
protected short fValidity = ElementPSVI.VALIDITY_NOTKNOWN;
|
||||
|
||||
/** error codes */
|
||||
protected String[] fErrorCodes = null;
|
||||
/** error codes and error messages */
|
||||
protected String[] fErrors = null;
|
||||
|
||||
/** validation context: could be QName or XPath expression*/
|
||||
protected String fValidationContext = null;
|
||||
@ -97,10 +89,65 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
/** the schema information property */
|
||||
protected XSModel fSchemaInformation = null;
|
||||
|
||||
/** true if this object is immutable **/
|
||||
protected boolean fIsConstant;
|
||||
|
||||
public ElementPSVImpl() {}
|
||||
|
||||
public ElementPSVImpl(boolean isConstant, ElementPSVI elementPSVI) {
|
||||
fDeclaration = elementPSVI.getElementDeclaration();
|
||||
fTypeDecl = elementPSVI.getTypeDefinition();
|
||||
fNil = elementPSVI.getNil();
|
||||
fSpecified = elementPSVI.getIsSchemaSpecified();
|
||||
fValue.copyFrom(elementPSVI.getSchemaValue());
|
||||
fNotation = elementPSVI.getNotation();
|
||||
fValidationAttempted = elementPSVI.getValidationAttempted();
|
||||
fValidity = elementPSVI.getValidity();
|
||||
fValidationContext = elementPSVI.getValidationContext();
|
||||
if (elementPSVI instanceof ElementPSVImpl) {
|
||||
final ElementPSVImpl elementPSVIImpl = (ElementPSVImpl) elementPSVI;
|
||||
fErrors = (elementPSVIImpl.fErrors != null) ?
|
||||
(String[]) elementPSVIImpl.fErrors.clone() : null;
|
||||
elementPSVIImpl.copySchemaInformationTo(this);
|
||||
}
|
||||
else {
|
||||
final StringList errorCodes = elementPSVI.getErrorCodes();
|
||||
final int length = errorCodes.getLength();
|
||||
if (length > 0) {
|
||||
final StringList errorMessages = elementPSVI.getErrorMessages();
|
||||
final String[] errors = new String[length << 1];
|
||||
for (int i = 0, j = 0; i < length; ++i) {
|
||||
errors[j++] = errorCodes.item(i);
|
||||
errors[j++] = errorMessages.item(i);
|
||||
}
|
||||
fErrors = errors;
|
||||
}
|
||||
fSchemaInformation = elementPSVI.getSchemaInformation();
|
||||
}
|
||||
fIsConstant = isConstant;
|
||||
}
|
||||
|
||||
//
|
||||
// ElementPSVI methods
|
||||
//
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.apache.xerces.xs.ItemPSVI#constant()
|
||||
*/
|
||||
public ItemPSVI constant() {
|
||||
if (isConstant()) {
|
||||
return this;
|
||||
}
|
||||
return new ElementPSVImpl(true, this);
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.apache.xerces.xs.ItemPSVI#isConstant()
|
||||
*/
|
||||
public boolean isConstant() {
|
||||
return fIsConstant;
|
||||
}
|
||||
|
||||
/**
|
||||
* [schema default]
|
||||
*
|
||||
@ -119,7 +166,7 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
* @return the normalized value of this item after validation
|
||||
*/
|
||||
public String getSchemaNormalizedValue() {
|
||||
return fNormalizedValue;
|
||||
return fValue.getNormalizedValue();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -159,11 +206,24 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
* @return Array of error codes
|
||||
*/
|
||||
public StringList getErrorCodes() {
|
||||
if (fErrorCodes == null)
|
||||
return null;
|
||||
return new StringListImpl(fErrorCodes, fErrorCodes.length);
|
||||
if (fErrors == null || fErrors.length == 0) {
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
return new PSVIErrorList(fErrors, true);
|
||||
}
|
||||
|
||||
/**
|
||||
* A list of error messages generated from the validation attempt or
|
||||
* an empty <code>StringList</code> if no errors occurred during the
|
||||
* validation attempt. The indices of error messages in this list are
|
||||
* aligned with those in the <code>[schema error code]</code> list.
|
||||
*/
|
||||
public StringList getErrorMessages() {
|
||||
if (fErrors == null || fErrors.length == 0) {
|
||||
return StringListImpl.EMPTY_LIST;
|
||||
}
|
||||
return new PSVIErrorList(fErrors, false);
|
||||
}
|
||||
|
||||
// This is the only information we can provide in a pipeline.
|
||||
public String getValidationContext() {
|
||||
@ -207,7 +267,7 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
* @return a simple type declaration
|
||||
*/
|
||||
public XSSimpleTypeDefinition getMemberTypeDefinition() {
|
||||
return fMemberType;
|
||||
return fValue.getMemberTypeDefinition();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -237,21 +297,28 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValue()
|
||||
*/
|
||||
public Object getActualNormalizedValue() {
|
||||
return this.fActualValue;
|
||||
return fValue.getActualValue();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValueType()
|
||||
*/
|
||||
public short getActualNormalizedValueType() {
|
||||
return this.fActualValueType;
|
||||
return fValue.getActualValueType();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getItemValueTypes()
|
||||
*/
|
||||
public ShortList getItemValueTypes() {
|
||||
return this.fItemValueTypes;
|
||||
return fValue.getListValueTypes();
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getSchemaValue()
|
||||
*/
|
||||
public XSValue getSchemaValue() {
|
||||
return fValue;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -263,15 +330,15 @@ public class ElementPSVImpl implements ElementPSVI {
|
||||
fNil = false;
|
||||
fSpecified = false;
|
||||
fNotation = null;
|
||||
fMemberType = null;
|
||||
fValidationAttempted = ElementPSVI.VALIDATION_NONE;
|
||||
fValidity = ElementPSVI.VALIDITY_NOTKNOWN;
|
||||
fErrorCodes = null;
|
||||
fErrors = null;
|
||||
fValidationContext = null;
|
||||
fNormalizedValue = null;
|
||||
fActualValue = null;
|
||||
fActualValueType = XSConstants.UNAVAILABLE_DT;
|
||||
fItemValueTypes = null;
|
||||
fValue.reset();
|
||||
}
|
||||
|
||||
public void copySchemaInformationTo(ElementPSVImpl target) {
|
||||
target.fGrammars = fGrammars;
|
||||
target.fSchemaInformation = fSchemaInformation;
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,92 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.xs;
|
||||
|
||||
import java.util.AbstractList;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.xs.StringList;
|
||||
|
||||
/**
|
||||
* StringList implementation for schema error codes and error messages.
|
||||
*
|
||||
* @xerces.internal
|
||||
*
|
||||
* @author Michael Glavassevich, IBM
|
||||
*
|
||||
*/
|
||||
final class PSVIErrorList extends AbstractList implements StringList {
|
||||
|
||||
private final String[] fArray;
|
||||
private final int fLength;
|
||||
private final int fOffset;
|
||||
|
||||
public PSVIErrorList(String[] array, boolean even) {
|
||||
fArray = array;
|
||||
fLength = (fArray.length >> 1);
|
||||
fOffset = even ? 0 : 1;
|
||||
}
|
||||
|
||||
public boolean contains(String item) {
|
||||
if (item == null) {
|
||||
for (int i = 0; i < fLength; ++i) {
|
||||
if (fArray[(i << 1) + fOffset] == null) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
for (int i = 0; i < fLength; ++i) {
|
||||
if (item.equals(fArray[(i << 1) + fOffset])) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public int getLength() {
|
||||
return fLength;
|
||||
}
|
||||
|
||||
public String item(int index) {
|
||||
if (index < 0 || index >= fLength) {
|
||||
return null;
|
||||
}
|
||||
return fArray[(index << 1) + fOffset];
|
||||
}
|
||||
|
||||
/*
|
||||
* List methods
|
||||
*/
|
||||
|
||||
public Object get(int index) {
|
||||
if (index >= 0 && index < fLength) {
|
||||
return fArray[(index << 1) + fOffset];
|
||||
}
|
||||
throw new IndexOutOfBoundsException("Index: " + index);
|
||||
}
|
||||
|
||||
public int size() {
|
||||
return getLength();
|
||||
}
|
||||
|
||||
} // class PSVIErrorList
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,9 +21,6 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.xs;
|
||||
|
||||
import java.lang.ref.SoftReference;
|
||||
import java.util.Vector;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.impl.Constants;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.SchemaDVFactory;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.ValidatedInfo;
|
||||
@ -49,6 +47,7 @@ import com.sun.org.apache.xerces.internal.xs.XSAttributeDeclaration;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSAttributeGroupDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSElementDeclaration;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSIDCDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSModel;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSModelGroupDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNamedMap;
|
||||
@ -59,6 +58,8 @@ import com.sun.org.apache.xerces.internal.xs.XSParticle;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSWildcard;
|
||||
import com.sun.org.apache.xerces.internal.xs.datatypes.ObjectList;
|
||||
import java.lang.ref.SoftReference;
|
||||
import java.util.Vector;
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
/**
|
||||
@ -135,7 +136,7 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
* Default constructor.
|
||||
*
|
||||
* @param targetNamespace
|
||||
* @param grammarDesc the XMLGrammarDescription corresponding to this objec
|
||||
* @param grammarDesc the XMLGrammarDescription corresponding to this object
|
||||
* at the least a systemId should always be known.
|
||||
* @param symbolTable needed for annotation support
|
||||
*/
|
||||
@ -145,35 +146,39 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
fGrammarDescription = grammarDesc;
|
||||
fSymbolTable = symbolTable;
|
||||
|
||||
// REVISIT: do we know the numbers of the following global decls
|
||||
// when creating this grammar? If so, we can pass the numbers in,
|
||||
// and use that number to initialize the following hashtables.
|
||||
fGlobalAttrDecls = new SymbolHash();
|
||||
fGlobalAttrGrpDecls = new SymbolHash();
|
||||
fGlobalElemDecls = new SymbolHash();
|
||||
fGlobalGroupDecls = new SymbolHash();
|
||||
fGlobalNotationDecls = new SymbolHash();
|
||||
fGlobalIDConstraintDecls = new SymbolHash();
|
||||
// REVISIT: the initial sizes being chosen for each SymbolHash
|
||||
// may not be ideal and could still be tuned. They were chosen
|
||||
// somewhat arbitrarily to reduce the initial footprint of
|
||||
// SymbolHash buckets from 1,515 to 177 (about 12% of the
|
||||
// default size).
|
||||
fGlobalAttrDecls = new SymbolHash(12);
|
||||
fGlobalAttrGrpDecls = new SymbolHash(5);
|
||||
fGlobalElemDecls = new SymbolHash(25);
|
||||
fGlobalGroupDecls = new SymbolHash(5);
|
||||
fGlobalNotationDecls = new SymbolHash(1);
|
||||
fGlobalIDConstraintDecls = new SymbolHash(3);
|
||||
|
||||
// Extended tables
|
||||
fGlobalAttrDeclsExt = new SymbolHash();
|
||||
fGlobalAttrGrpDeclsExt = new SymbolHash();
|
||||
fGlobalElemDeclsExt = new SymbolHash();
|
||||
fGlobalGroupDeclsExt = new SymbolHash();
|
||||
fGlobalNotationDeclsExt = new SymbolHash();
|
||||
fGlobalIDConstraintDeclsExt = new SymbolHash();
|
||||
fGlobalTypeDeclsExt = new SymbolHash();
|
||||
fGlobalAttrDeclsExt = new SymbolHash(12);
|
||||
fGlobalAttrGrpDeclsExt = new SymbolHash(5);
|
||||
fGlobalElemDeclsExt = new SymbolHash(25);
|
||||
fGlobalGroupDeclsExt = new SymbolHash(5);
|
||||
fGlobalNotationDeclsExt = new SymbolHash(1);
|
||||
fGlobalIDConstraintDeclsExt = new SymbolHash(3);
|
||||
fGlobalTypeDeclsExt = new SymbolHash(25);
|
||||
|
||||
// All global elements table
|
||||
fAllGlobalElemDecls = new SymbolHash();
|
||||
fAllGlobalElemDecls = new SymbolHash(25);
|
||||
|
||||
// if we are parsing S4S, put built-in types in first
|
||||
// they might get overwritten by the types from S4S, but that's
|
||||
// considered what the application wants to do.
|
||||
if (fTargetNamespace == SchemaSymbols.URI_SCHEMAFORSCHEMA)
|
||||
if (fTargetNamespace == SchemaSymbols.URI_SCHEMAFORSCHEMA) {
|
||||
fGlobalTypeDecls = SG_SchemaNS.fGlobalTypeDecls.makeClone();
|
||||
else
|
||||
fGlobalTypeDecls = new SymbolHash();
|
||||
}
|
||||
else {
|
||||
fGlobalTypeDecls = new SymbolHash(25);
|
||||
}
|
||||
} // <init>(String, XSDDescription)
|
||||
|
||||
// Clone an existing schema grammar
|
||||
@ -232,7 +237,7 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
fRedefinedGroupDecls = new XSGroupDecl[grammar.fRedefinedGroupDecls.length];
|
||||
fRGLocators = new SimpleLocator[grammar.fRGLocators.length];
|
||||
System.arraycopy(grammar.fRedefinedGroupDecls, 0, fRedefinedGroupDecls, 0, fRGCount);
|
||||
System.arraycopy(grammar.fRGLocators, 0, fRGLocators, 0, fRGCount);
|
||||
System.arraycopy(grammar.fRGLocators, 0, fRGLocators, 0, fRGCount/2);
|
||||
}
|
||||
|
||||
// List of imported grammars
|
||||
@ -626,19 +631,19 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
// fill complex types
|
||||
annotationType.setValues("#AnonType_" + SchemaSymbols.ELT_ANNOTATION, fTargetNamespace, SchemaGrammar.fAnyType,
|
||||
XSConstants.DERIVATION_RESTRICTION, XSConstants.DERIVATION_NONE, (short) (XSConstants.DERIVATION_EXTENSION | XSConstants.DERIVATION_RESTRICTION),
|
||||
XSComplexTypeDecl.CONTENTTYPE_ELEMENT, false, annotationAttrs, null, annotationParticle, new XSObjectListImpl(null, 0));
|
||||
XSComplexTypeDecl.CONTENTTYPE_ELEMENT, false, annotationAttrs, null, annotationParticle, XSObjectListImpl.EMPTY_LIST);
|
||||
annotationType.setName("#AnonType_" + SchemaSymbols.ELT_ANNOTATION);
|
||||
annotationType.setIsAnonymous();
|
||||
|
||||
documentationType.setValues("#AnonType_" + SchemaSymbols.ELT_DOCUMENTATION, fTargetNamespace, SchemaGrammar.fAnyType,
|
||||
XSConstants.DERIVATION_RESTRICTION, XSConstants.DERIVATION_NONE, (short) (XSConstants.DERIVATION_EXTENSION | XSConstants.DERIVATION_RESTRICTION),
|
||||
XSComplexTypeDecl.CONTENTTYPE_MIXED, false, documentationAttrs, null, anyWCSequenceParticle, new XSObjectListImpl(null, 0));
|
||||
XSComplexTypeDecl.CONTENTTYPE_MIXED, false, documentationAttrs, null, anyWCSequenceParticle, XSObjectListImpl.EMPTY_LIST);
|
||||
documentationType.setName("#AnonType_" + SchemaSymbols.ELT_DOCUMENTATION);
|
||||
documentationType.setIsAnonymous();
|
||||
|
||||
appinfoType.setValues("#AnonType_" + SchemaSymbols.ELT_APPINFO, fTargetNamespace, SchemaGrammar.fAnyType,
|
||||
XSConstants.DERIVATION_RESTRICTION, XSConstants.DERIVATION_NONE, (short) (XSConstants.DERIVATION_EXTENSION | XSConstants.DERIVATION_RESTRICTION),
|
||||
XSComplexTypeDecl.CONTENTTYPE_MIXED, false, appinfoAttrs, null, anyWCSequenceParticle, new XSObjectListImpl(null, 0));
|
||||
XSComplexTypeDecl.CONTENTTYPE_MIXED, false, appinfoAttrs, null, anyWCSequenceParticle, XSObjectListImpl.EMPTY_LIST);
|
||||
appinfoType.setName("#AnonType_" + SchemaSymbols.ELT_APPINFO);
|
||||
appinfoType.setIsAnonymous();
|
||||
|
||||
@ -1178,8 +1183,8 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
fDerivedBy = XSConstants.DERIVATION_RESTRICTION;
|
||||
fContentType = XSComplexTypeDecl.CONTENTTYPE_MIXED;
|
||||
|
||||
fParticle = null;
|
||||
fAttrGrp = null;
|
||||
fParticle = createParticle();
|
||||
fAttrGrp = createAttrGrp();
|
||||
}
|
||||
|
||||
// overridden methods
|
||||
@ -1211,11 +1216,15 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
// null implementation
|
||||
}
|
||||
|
||||
public XSObjectList getAttributeUses() {
|
||||
public XSObjectList getAnnotations() {
|
||||
return XSObjectListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
public XSAttributeGroupDecl getAttrGrp() {
|
||||
public XSNamespaceItem getNamespaceItem() {
|
||||
return SG_SchemaNS;
|
||||
}
|
||||
|
||||
private XSAttributeGroupDecl createAttrGrp() {
|
||||
XSWildcardDecl wildcard = new XSWildcardDecl();
|
||||
wildcard.fProcessContents = XSWildcardDecl.PC_LAX;
|
||||
XSAttributeGroupDecl attrGrp = new XSAttributeGroupDecl();
|
||||
@ -1223,13 +1232,7 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
return attrGrp;
|
||||
}
|
||||
|
||||
public XSWildcard getAttributeWildcard() {
|
||||
XSWildcardDecl wildcard = new XSWildcardDecl();
|
||||
wildcard.fProcessContents = XSWildcardDecl.PC_LAX;
|
||||
return wildcard;
|
||||
}
|
||||
|
||||
public XSParticle getParticle() {
|
||||
private XSParticleDecl createParticle() {
|
||||
// the wildcard used in anyType (content and attribute)
|
||||
// the spec will change strict to skip for anyType
|
||||
XSWildcardDecl wildcard = new XSWildcardDecl();
|
||||
@ -1253,14 +1256,6 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
|
||||
return particleG;
|
||||
}
|
||||
|
||||
public XSObjectList getAnnotations() {
|
||||
return XSObjectListImpl.EMPTY_LIST;
|
||||
}
|
||||
|
||||
public XSNamespaceItem getNamespaceItem() {
|
||||
return SG_SchemaNS;
|
||||
}
|
||||
}
|
||||
private static class BuiltinAttrDecl extends XSAttributeDecl {
|
||||
public BuiltinAttrDecl(String name, String tns,
|
||||
@ -1347,7 +1342,7 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
false, // model group
|
||||
false, // particle
|
||||
false, // wildcard
|
||||
false, // idc
|
||||
true, // idc
|
||||
true, // notation
|
||||
false, // annotation
|
||||
false, // facet
|
||||
@ -1484,6 +1479,9 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
case XSConstants.NOTATION_DECLARATION:
|
||||
table = fGlobalNotationDecls;
|
||||
break;
|
||||
case XSConstants.IDENTITY_CONSTRAINT:
|
||||
table = this.fGlobalIDConstraintDecls;
|
||||
break;
|
||||
}
|
||||
|
||||
// for complex/simple types, create a special implementation,
|
||||
@ -1533,6 +1531,9 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
case XSConstants.NOTATION_DECLARATION:
|
||||
table = fGlobalNotationDeclsExt;
|
||||
break;
|
||||
case XSConstants.IDENTITY_CONSTRAINT:
|
||||
table = this.fGlobalIDConstraintDeclsExt;
|
||||
break;
|
||||
}
|
||||
|
||||
Object[] entries = table.getEntries();
|
||||
@ -1610,6 +1611,10 @@ public class SchemaGrammar implements XSGrammar, XSNamespaceItem {
|
||||
return getGlobalNotationDecl(name);
|
||||
}
|
||||
|
||||
public XSIDCDefinition getIDCDefinition(String name) {
|
||||
return getIDConstraintDecl(name);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* [document location]
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -40,14 +41,14 @@ public class SubstitutionGroupHandler {
|
||||
|
||||
private static final XSElementDecl[] EMPTY_GROUP = new XSElementDecl[0];
|
||||
|
||||
// grammar resolver
|
||||
XSGrammarBucket fGrammarBucket;
|
||||
// global element declaration resolver
|
||||
private final XSElementDeclHelper fXSElementDeclHelper;
|
||||
|
||||
/**
|
||||
* Default constructor
|
||||
*/
|
||||
public SubstitutionGroupHandler(XSGrammarBucket grammarBucket) {
|
||||
fGrammarBucket = grammarBucket;
|
||||
public SubstitutionGroupHandler(XSElementDeclHelper elementDeclHelper) {
|
||||
fXSElementDeclHelper = elementDeclHelper;
|
||||
}
|
||||
|
||||
// 3.9.4 Element Sequence Locally Valid (Particle) 2.3.3
|
||||
@ -60,26 +61,25 @@ public class SubstitutionGroupHandler {
|
||||
|
||||
// if the exemplar is not a global element decl, then it's not possible
|
||||
// to be substituted by another element.
|
||||
if (exemplar.fScope != XSConstants.SCOPE_GLOBAL)
|
||||
if (exemplar.fScope != XSConstants.SCOPE_GLOBAL) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// if the decl blocks substitution, return false
|
||||
if ((exemplar.fBlock & XSConstants.DERIVATION_SUBSTITUTION) != 0)
|
||||
return null;
|
||||
|
||||
// get grammar of the element
|
||||
SchemaGrammar sGrammar = fGrammarBucket.getGrammar(element.uri);
|
||||
if (sGrammar == null)
|
||||
if ((exemplar.fBlock & XSConstants.DERIVATION_SUBSTITUTION) != 0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// get the decl for the element
|
||||
XSElementDecl eDecl = sGrammar.getGlobalElementDecl(element.localpart);
|
||||
if (eDecl == null)
|
||||
XSElementDecl eDecl = fXSElementDeclHelper.getGlobalElementDecl(element);
|
||||
if (eDecl == null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// and check by using substitutionGroup information
|
||||
if (substitutionGroupOK(eDecl, exemplar, exemplar.fBlock))
|
||||
if (substitutionGroupOK(eDecl, exemplar, exemplar.fBlock)) {
|
||||
return eDecl;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
@ -89,13 +89,15 @@ public class SubstitutionGroupHandler {
|
||||
protected boolean substitutionGroupOK(XSElementDecl element, XSElementDecl exemplar, short blockingConstraint) {
|
||||
// For an element declaration (call it D) to be validly substitutable for another element declaration (call it C) subject to a blocking constraint (a subset of {substitution, extension, restriction}, the value of a {disallowed substitutions}) one of the following must be true:
|
||||
// 1. D and C are the same element declaration.
|
||||
if (element == exemplar)
|
||||
if (element == exemplar) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// 2 All of the following must be true:
|
||||
// 2.1 The blocking constraint does not contain substitution.
|
||||
if ((blockingConstraint & XSConstants.DERIVATION_SUBSTITUTION) != 0)
|
||||
if ((blockingConstraint & XSConstants.DERIVATION_SUBSTITUTION) != 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// 2.2 There is a chain of {substitution group affiliation}s from D to C, that is, either D's {substitution group affiliation} is C, or D's {substitution group affiliation}'s {substitution group affiliation} is C, or . . .
|
||||
XSElementDecl subGroup = element.fSubGroup;
|
||||
@ -103,14 +105,16 @@ public class SubstitutionGroupHandler {
|
||||
subGroup = subGroup.fSubGroup;
|
||||
}
|
||||
|
||||
if (subGroup == null)
|
||||
if (subGroup == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// 2.3 The set of all {derivation method}s involved in the derivation of D's {type definition} from C's {type definition} does not intersect with the union of the blocking constraint, C's {prohibited substitutions} (if C is complex, otherwise the empty set) and the {prohibited substitutions} (respectively the empty set) of any intermediate {type definition}s in the derivation of D's {type definition} from C's {type definition}.
|
||||
// prepare the combination of {derivation method} and
|
||||
// {disallowed substitution}
|
||||
return typeDerivationOK(element.fType, exemplar.fType, blockingConstraint);
|
||||
}
|
||||
|
||||
private boolean typeDerivationOK(XSTypeDefinition derived, XSTypeDefinition base, short blockingConstraint) {
|
||||
|
||||
short devMethod = 0, blockConstraint = blockingConstraint;
|
||||
|
@ -1,13 +1,13 @@
|
||||
/*
|
||||
* reserved comment block
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||
*/
|
||||
/*
|
||||
* Copyright 2000-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -20,26 +20,12 @@
|
||||
|
||||
package com.sun.org.apache.xerces.internal.impl.xs;
|
||||
|
||||
import java.io.BufferedInputStream;
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.Reader;
|
||||
import java.io.StringReader;
|
||||
import java.util.Hashtable;
|
||||
import java.util.Locale;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.Vector;
|
||||
|
||||
import com.sun.org.apache.xerces.internal.dom.DOMErrorImpl;
|
||||
import com.sun.org.apache.xerces.internal.dom.DOMMessageFormatter;
|
||||
import com.sun.org.apache.xerces.internal.dom.DOMStringListImpl;
|
||||
import com.sun.org.apache.xerces.internal.impl.Constants;
|
||||
import com.sun.org.apache.xerces.internal.impl.XMLEntityManager;
|
||||
import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.DVFactoryException;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.InvalidDatatypeValueException;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.SchemaDVFactory;
|
||||
import com.sun.org.apache.xerces.internal.impl.dv.xs.SchemaDVFactoryImpl;
|
||||
@ -49,13 +35,16 @@ import com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler;
|
||||
import com.sun.org.apache.xerces.internal.util.DOMEntityResolverWrapper;
|
||||
import com.sun.org.apache.xerces.internal.util.DOMErrorHandlerWrapper;
|
||||
import com.sun.org.apache.xerces.internal.util.DefaultErrorHandler;
|
||||
import com.sun.org.apache.xerces.internal.util.MessageFormatter;
|
||||
import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;
|
||||
import com.sun.org.apache.xerces.internal.util.Status;
|
||||
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
||||
import com.sun.org.apache.xerces.internal.util.URI.MalformedURIException;
|
||||
import com.sun.org.apache.xerces.internal.util.XMLSymbols;
|
||||
import com.sun.org.apache.xerces.internal.utils.SecuritySupport;
|
||||
import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager;
|
||||
import com.sun.org.apache.xerces.internal.utils.XMLSecurityPropertyManager;
|
||||
import com.sun.org.apache.xerces.internal.xni.QName;
|
||||
import com.sun.org.apache.xerces.internal.xni.XNIException;
|
||||
import com.sun.org.apache.xerces.internal.xni.grammars.Grammar;
|
||||
import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarDescription;
|
||||
@ -72,14 +61,26 @@ import com.sun.org.apache.xerces.internal.xs.LSInputList;
|
||||
import com.sun.org.apache.xerces.internal.xs.StringList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSLoader;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSModel;
|
||||
import java.io.BufferedInputStream;
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.Reader;
|
||||
import java.io.StringReader;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.Locale;
|
||||
import java.util.Map;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.WeakHashMap;
|
||||
import javax.xml.XMLConstants;
|
||||
import org.w3c.dom.DOMConfiguration;
|
||||
import org.w3c.dom.DOMError;
|
||||
import org.w3c.dom.DOMErrorHandler;
|
||||
import org.w3c.dom.DOMStringList;
|
||||
import org.w3c.dom.DOMException;
|
||||
import org.w3c.dom.DOMStringList;
|
||||
import org.w3c.dom.ls.LSInput;
|
||||
import org.w3c.dom.ls.LSResourceResolver;
|
||||
import org.xml.sax.InputSource;
|
||||
@ -101,7 +102,7 @@ import org.xml.sax.InputSource;
|
||||
* @author Neil Graham, IBM
|
||||
*/
|
||||
|
||||
public class XMLSchemaLoader implements XMLGrammarLoader, XMLComponent,
|
||||
public class XMLSchemaLoader implements XMLGrammarLoader, XMLComponent, XSElementDeclHelper,
|
||||
// XML Component API
|
||||
XSLoader, DOMConfiguration {
|
||||
|
||||
@ -249,8 +250,7 @@ XSLoader, DOMConfiguration {
|
||||
// Data
|
||||
|
||||
// features and properties
|
||||
private ParserConfigurationSettings fLoaderConfig = new ParserConfigurationSettings();
|
||||
private SymbolTable fSymbolTable = null;
|
||||
private final ParserConfigurationSettings fLoaderConfig = new ParserConfigurationSettings();
|
||||
private XMLErrorReporter fErrorReporter = new XMLErrorReporter ();
|
||||
private XMLEntityManager fEntityManager = null;
|
||||
private XMLEntityResolver fUserEntityResolver = null;
|
||||
@ -276,7 +276,7 @@ XSLoader, DOMConfiguration {
|
||||
private XSDDescription fXSDDescription = new XSDDescription();
|
||||
private String faccessExternalSchema = Constants.EXTERNAL_ACCESS_DEFAULT;
|
||||
|
||||
private Map fJAXPCache;
|
||||
private WeakHashMap fJAXPCache;
|
||||
private Locale fLocale = Locale.getDefault();
|
||||
|
||||
// XSLoader attributes
|
||||
@ -350,8 +350,8 @@ XSLoader, DOMConfiguration {
|
||||
grammarBucket = new XSGrammarBucket();
|
||||
}
|
||||
fGrammarBucket = grammarBucket;
|
||||
if(sHandler == null) {
|
||||
sHandler = new SubstitutionGroupHandler(fGrammarBucket);
|
||||
if (sHandler == null) {
|
||||
sHandler = new SubstitutionGroupHandler(this);
|
||||
}
|
||||
fSubGroupHandler = sHandler;
|
||||
|
||||
@ -360,10 +360,7 @@ XSLoader, DOMConfiguration {
|
||||
}
|
||||
fCMBuilder = builder;
|
||||
fSchemaHandler = new XSDHandler(fGrammarBucket);
|
||||
if (fDeclPool != null) {
|
||||
fDeclPool.reset();
|
||||
}
|
||||
fJAXPCache = new HashMap();
|
||||
fJAXPCache = new WeakHashMap();
|
||||
|
||||
fSettingsChanged = true;
|
||||
}
|
||||
@ -527,8 +524,8 @@ XSLoader, DOMConfiguration {
|
||||
* Returns a Grammar object by parsing the contents of the
|
||||
* entities pointed to by sources.
|
||||
*
|
||||
* @param source[] the locations of the entity which forms
|
||||
* the staring point of the grammars to be constructed
|
||||
* @param source the locations of the entity which forms
|
||||
* the staring point of the grammars to be constructed
|
||||
* @throws IOException when a problem is encounted reading the entity
|
||||
* @throws XNIException when a condition arises (such as a FatalError) that requires parsing
|
||||
* of the entity be terminated
|
||||
@ -618,7 +615,8 @@ XSLoader, DOMConfiguration {
|
||||
return grammar;
|
||||
} // loadSchema(XSDDescription, XMLInputSource): SchemaGrammar
|
||||
|
||||
/** This method tries to resolve location of the given schema.
|
||||
/**
|
||||
* This method tries to resolve location of the given schema.
|
||||
* The loader stores the namespace/location pairs in a hashtable (use "" as the
|
||||
* namespace of absent namespace). When resolving an entity, loader first tries
|
||||
* to find in the hashtable whether there is a value for that namespace,
|
||||
@ -627,7 +625,7 @@ XSLoader, DOMConfiguration {
|
||||
* @param desc
|
||||
* @param locationPairs
|
||||
* @param entityResolver
|
||||
* @return
|
||||
* @return the XMLInputSource
|
||||
* @throws IOException
|
||||
*/
|
||||
public static XMLInputSource resolveDocument(XSDDescription desc, Map locationPairs,
|
||||
@ -671,7 +669,7 @@ XSLoader, DOMConfiguration {
|
||||
XSAttributeDecl attrDecl = SchemaGrammar.SG_XSI.getGlobalAttributeDecl(SchemaSymbols.XSI_SCHEMALOCATION);
|
||||
// validation the string value to get the list of URI's
|
||||
attrDecl.fType.validate(sl, null, null);
|
||||
if (!tokenizeSchemaLocationStr(sl, locations)) {
|
||||
if (!tokenizeSchemaLocationStr(sl, locations, null)) {
|
||||
// report warning (odd number of items)
|
||||
er.reportError(XSMessageFormatter.SCHEMA_DOMAIN,
|
||||
"SchemaLocation",
|
||||
@ -714,7 +712,7 @@ XSLoader, DOMConfiguration {
|
||||
// @param schemaStr The schemaLocation string to tokenize
|
||||
// @param locations HashMap mapping namespaces to LocationArray objects holding lists of locaitons
|
||||
// @return true if no problems; false if string could not be tokenized
|
||||
public static boolean tokenizeSchemaLocationStr(String schemaStr, Map locations) {
|
||||
public static boolean tokenizeSchemaLocationStr(String schemaStr, Map locations, String base) {
|
||||
if (schemaStr!= null) {
|
||||
StringTokenizer t = new StringTokenizer(schemaStr, " \n\t\r");
|
||||
String namespace, location;
|
||||
@ -729,6 +727,12 @@ XSLoader, DOMConfiguration {
|
||||
la = new LocationArray();
|
||||
locations.put(namespace, la);
|
||||
}
|
||||
if (base != null) {
|
||||
try {
|
||||
location = XMLEntityManager.expandSystemId(location, base, false);
|
||||
} catch (MalformedURIException e) {
|
||||
}
|
||||
}
|
||||
la.addLocation(location);
|
||||
}
|
||||
}
|
||||
@ -756,10 +760,10 @@ XSLoader, DOMConfiguration {
|
||||
String sid = null;
|
||||
if (componentType == null) {
|
||||
// Not an array
|
||||
if(fJAXPSource instanceof InputStream ||
|
||||
if (fJAXPSource instanceof InputStream ||
|
||||
fJAXPSource instanceof InputSource) {
|
||||
SchemaGrammar g = (SchemaGrammar)fJAXPCache.get(fJAXPSource);
|
||||
if(g != null) {
|
||||
if (g != null) {
|
||||
fGrammarBucket.putGrammar(g);
|
||||
return;
|
||||
}
|
||||
@ -776,38 +780,40 @@ XSLoader, DOMConfiguration {
|
||||
}
|
||||
SchemaGrammar g = loadSchema(fXSDDescription, xis, locationPairs);
|
||||
// it is possible that we won't be able to resolve JAXP schema-source location
|
||||
if (g != null){
|
||||
if(fJAXPSource instanceof InputStream ||
|
||||
if (g != null) {
|
||||
if (fJAXPSource instanceof InputStream ||
|
||||
fJAXPSource instanceof InputSource) {
|
||||
fJAXPCache.put(fJAXPSource, g);
|
||||
if(fIsCheckedFully) {
|
||||
if (fIsCheckedFully) {
|
||||
XSConstraints.fullSchemaChecking(fGrammarBucket, fSubGroupHandler, fCMBuilder, fErrorReporter);
|
||||
}
|
||||
}
|
||||
fGrammarBucket.putGrammar(g);
|
||||
}
|
||||
return ;
|
||||
} else if ( (componentType != Object.class) &&
|
||||
return;
|
||||
}
|
||||
else if ( (componentType != Object.class) &&
|
||||
(componentType != String.class) &&
|
||||
(componentType != File.class) &&
|
||||
(componentType != InputStream.class) &&
|
||||
(componentType != InputSource.class)
|
||||
!File.class.isAssignableFrom(componentType) &&
|
||||
!InputStream.class.isAssignableFrom(componentType) &&
|
||||
!InputSource.class.isAssignableFrom(componentType) &&
|
||||
!componentType.isInterface()
|
||||
) {
|
||||
// Not an Object[], String[], File[], InputStream[], InputSource[]
|
||||
MessageFormatter mf = fErrorReporter.getMessageFormatter(XSMessageFormatter.SCHEMA_DOMAIN);
|
||||
throw new XMLConfigurationException(
|
||||
Status.NOT_SUPPORTED, "\""+JAXP_SCHEMA_SOURCE+
|
||||
"\" property cannot have an array of type {"+componentType.getName()+
|
||||
"}. Possible types of the array supported are Object, String, File, "+
|
||||
"InputStream, InputSource.");
|
||||
Status.NOT_SUPPORTED,
|
||||
mf.formatMessage(fErrorReporter.getLocale(), "jaxp12-schema-source-type.2",
|
||||
new Object [] {componentType.getName()}));
|
||||
}
|
||||
|
||||
// JAXP spec. allow []s of type String, File, InputStream,
|
||||
// InputSource also, apart from [] of type Object.
|
||||
Object[] objArr = (Object[]) fJAXPSource;
|
||||
//make local vector for storing targetn namespaces of schemasources specified in object arrays.
|
||||
Vector jaxpSchemaSourceNamespaces = new Vector() ;
|
||||
// make local array for storing target namespaces of schemasources specified in object arrays.
|
||||
ArrayList jaxpSchemaSourceNamespaces = new ArrayList();
|
||||
for (int i = 0; i < objArr.length; i++) {
|
||||
if(objArr[i] instanceof InputStream ||
|
||||
if (objArr[i] instanceof InputStream ||
|
||||
objArr[i] instanceof InputSource) {
|
||||
SchemaGrammar g = (SchemaGrammar)fJAXPCache.get(objArr[i]);
|
||||
if (g != null) {
|
||||
@ -829,18 +835,18 @@ XSLoader, DOMConfiguration {
|
||||
// load schema
|
||||
SchemaGrammar grammar = fSchemaHandler.parseSchema(xis,fXSDDescription, locationPairs);
|
||||
|
||||
if(fIsCheckedFully) {
|
||||
if (fIsCheckedFully) {
|
||||
XSConstraints.fullSchemaChecking(fGrammarBucket, fSubGroupHandler, fCMBuilder, fErrorReporter);
|
||||
}
|
||||
if(grammar != null){
|
||||
targetNamespace = grammar.getTargetNamespace() ;
|
||||
if(jaxpSchemaSourceNamespaces.contains(targetNamespace)){
|
||||
//when an array of objects is passed it is illegal to have two schemas that share same namespace.
|
||||
throw new java.lang.IllegalArgumentException(
|
||||
" When using array of Objects as the value of SCHEMA_SOURCE property , " +
|
||||
"no two Schemas should share the same targetNamespace. " );
|
||||
if (grammar != null) {
|
||||
targetNamespace = grammar.getTargetNamespace();
|
||||
if (jaxpSchemaSourceNamespaces.contains(targetNamespace)) {
|
||||
// when an array of objects is passed it is illegal to have two schemas that share same namespace.
|
||||
MessageFormatter mf = fErrorReporter.getMessageFormatter(XSMessageFormatter.SCHEMA_DOMAIN);
|
||||
throw new java.lang.IllegalArgumentException(mf.formatMessage(fErrorReporter.getLocale(),
|
||||
"jaxp12-schema-source-ns", null));
|
||||
}
|
||||
else{
|
||||
else {
|
||||
jaxpSchemaSourceNamespaces.add(targetNamespace) ;
|
||||
}
|
||||
if(objArr[i] instanceof InputStream ||
|
||||
@ -849,15 +855,13 @@ XSLoader, DOMConfiguration {
|
||||
}
|
||||
fGrammarBucket.putGrammar(grammar);
|
||||
}
|
||||
else{
|
||||
else {
|
||||
//REVISIT: What should be the acutal behavior if grammar can't be loaded as specified in schema source?
|
||||
}
|
||||
}
|
||||
}//processJAXPSchemaSource
|
||||
|
||||
private XMLInputSource xsdToXMLInputSource(
|
||||
Object val)
|
||||
{
|
||||
private XMLInputSource xsdToXMLInputSource(Object val) {
|
||||
if (val instanceof String) {
|
||||
// String value is treated as a URI that is passed through the
|
||||
// EntityResolver
|
||||
@ -867,7 +871,8 @@ XSLoader, DOMConfiguration {
|
||||
XMLInputSource xis = null;
|
||||
try {
|
||||
xis = fEntityManager.resolveEntity(fXSDDescription);
|
||||
} catch (IOException ex) {
|
||||
}
|
||||
catch (IOException ex) {
|
||||
fErrorReporter.reportError(XSMessageFormatter.SCHEMA_DOMAIN,
|
||||
"schema_reference.4",
|
||||
new Object[] { loc }, XMLErrorReporter.SEVERITY_ERROR);
|
||||
@ -878,12 +883,15 @@ XSLoader, DOMConfiguration {
|
||||
return new XMLInputSource(null, loc, null);
|
||||
}
|
||||
return xis;
|
||||
} else if (val instanceof InputSource) {
|
||||
}
|
||||
else if (val instanceof InputSource) {
|
||||
return saxToXMLInputSource((InputSource) val);
|
||||
} else if (val instanceof InputStream) {
|
||||
}
|
||||
else if (val instanceof InputStream) {
|
||||
return new XMLInputSource(null, null, null,
|
||||
(InputStream) val, null);
|
||||
} else if (val instanceof File) {
|
||||
}
|
||||
else if (val instanceof File) {
|
||||
File file = (File) val;
|
||||
InputStream is = null;
|
||||
try {
|
||||
@ -893,13 +901,13 @@ XSLoader, DOMConfiguration {
|
||||
"schema_reference.4", new Object[] { file.toString() },
|
||||
XMLErrorReporter.SEVERITY_ERROR);
|
||||
}
|
||||
return new XMLInputSource(null, null, null, is, null);
|
||||
return new XMLInputSource(null, file.toURI().toString(), null, is, null);
|
||||
}
|
||||
MessageFormatter mf = fErrorReporter.getMessageFormatter(XSMessageFormatter.SCHEMA_DOMAIN);
|
||||
throw new XMLConfigurationException(
|
||||
Status.NOT_SUPPORTED, "\""+JAXP_SCHEMA_SOURCE+
|
||||
"\" property cannot have a value of type {"+val.getClass().getName()+
|
||||
"}. Possible types of the value supported are String, File, InputStream, "+
|
||||
"InputSource OR an array of these types.");
|
||||
Status.NOT_SUPPORTED,
|
||||
mf.formatMessage(fErrorReporter.getLocale(), "jaxp12-schema-source-type.1",
|
||||
new Object [] {val != null ? val.getClass().getName() : "null"}));
|
||||
}
|
||||
|
||||
|
||||
@ -999,13 +1007,22 @@ XSLoader, DOMConfiguration {
|
||||
|
||||
fSubGroupHandler.reset();
|
||||
|
||||
boolean parser_settings = componentManager.getFeature(PARSER_SETTINGS, true);
|
||||
boolean parser_settings = true;
|
||||
// If the component manager is the loader config don't bother querying it since it doesn't
|
||||
// recognize the PARSER_SETTINGS feature. Prevents an XMLConfigurationException from being
|
||||
// thrown.
|
||||
if (componentManager != fLoaderConfig) {
|
||||
parser_settings = componentManager.getFeature(PARSER_SETTINGS, true);
|
||||
}
|
||||
|
||||
if (!parser_settings || !fSettingsChanged){
|
||||
// need to reprocess JAXP schema sources
|
||||
fJAXPProcessed = false;
|
||||
// reinitialize grammar bucket
|
||||
initGrammarBucket();
|
||||
if (fDeclPool != null) {
|
||||
fDeclPool.reset();
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
@ -1028,26 +1045,6 @@ XSLoader, DOMConfiguration {
|
||||
fSchemaHandler.setDVFactory(dvFactory);
|
||||
}
|
||||
|
||||
boolean psvi = componentManager.getFeature(AUGMENT_PSVI, false);
|
||||
|
||||
if (!psvi) {
|
||||
if (fDeclPool != null) {
|
||||
fDeclPool.reset();
|
||||
}
|
||||
else {
|
||||
fDeclPool = new XSDeclarationPool();
|
||||
}
|
||||
fCMBuilder.setDeclPool(fDeclPool);
|
||||
fSchemaHandler.setDeclPool(fDeclPool);
|
||||
if (dvFactory instanceof SchemaDVFactoryImpl) {
|
||||
fDeclPool.setDVFactory((SchemaDVFactoryImpl)dvFactory);
|
||||
((SchemaDVFactoryImpl)dvFactory).setDeclPool(fDeclPool);
|
||||
}
|
||||
} else {
|
||||
fCMBuilder.setDeclPool(null);
|
||||
fSchemaHandler.setDeclPool(null);
|
||||
}
|
||||
|
||||
// get schema location properties
|
||||
try {
|
||||
fExternalSchemas = (String) componentManager.getProperty(SCHEMA_LOCATION);
|
||||
@ -1064,6 +1061,36 @@ XSLoader, DOMConfiguration {
|
||||
// clear grammars, and put the one for schema namespace there
|
||||
fGrammarPool = (XMLGrammarPool) componentManager.getProperty(XMLGRAMMAR_POOL, null);
|
||||
initGrammarBucket();
|
||||
|
||||
boolean psvi = componentManager.getFeature(AUGMENT_PSVI, false);
|
||||
|
||||
// Only use the decl pool when there is no chance that the schema
|
||||
// components will be exposed or cached.
|
||||
// TODO: when someone calls loadGrammar(XMLInputSource), the schema is
|
||||
// always exposed even without the use of a grammar pool.
|
||||
// Disabling the "decl pool" feature for now until we understand when
|
||||
// it can be safely used.
|
||||
if (!psvi && fGrammarPool == null && false) {
|
||||
if (fDeclPool != null) {
|
||||
fDeclPool.reset();
|
||||
}
|
||||
else {
|
||||
fDeclPool = new XSDeclarationPool();
|
||||
}
|
||||
fCMBuilder.setDeclPool(fDeclPool);
|
||||
fSchemaHandler.setDeclPool(fDeclPool);
|
||||
if (dvFactory instanceof SchemaDVFactoryImpl) {
|
||||
fDeclPool.setDVFactory((SchemaDVFactoryImpl)dvFactory);
|
||||
((SchemaDVFactoryImpl)dvFactory).setDeclPool(fDeclPool);
|
||||
}
|
||||
} else {
|
||||
fCMBuilder.setDeclPool(null);
|
||||
fSchemaHandler.setDeclPool(null);
|
||||
if (dvFactory instanceof SchemaDVFactoryImpl) {
|
||||
((SchemaDVFactoryImpl)dvFactory).setDeclPool(null);
|
||||
}
|
||||
}
|
||||
|
||||
// get continue-after-fatal-error feature
|
||||
try {
|
||||
boolean fatalError = componentManager.getFeature(CONTINUE_AFTER_FATAL_ERROR, false);
|
||||
@ -1083,7 +1110,8 @@ XSLoader, DOMConfiguration {
|
||||
private void initGrammarBucket(){
|
||||
if(fGrammarPool != null) {
|
||||
Grammar [] initialGrammars = fGrammarPool.retrieveInitialGrammarSet(XMLGrammarDescription.XML_SCHEMA);
|
||||
for (int i = 0; i < initialGrammars.length; i++) {
|
||||
final int length = (initialGrammars != null) ? initialGrammars.length : 0;
|
||||
for (int i = 0; i < length; ++i) {
|
||||
// put this grammar into the bucket, along with grammars
|
||||
// imported by it (directly or indirectly)
|
||||
if (!fGrammarBucket.putGrammar((SchemaGrammar)(initialGrammars[i]), true)) {
|
||||
@ -1119,7 +1147,7 @@ XSLoader, DOMConfiguration {
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.XSLoader#loadInputList(com.sun.org.apache.xerces.internal.xs.DOMInputList)
|
||||
* @see com.sun.org.apache.xerces.internal.xs.XSLoader#loadInputList(com.sun.org.apache.xerces.internal.xs.LSInputList)
|
||||
*/
|
||||
public XSModel loadInputList(LSInputList is) {
|
||||
int length = is.getLength();
|
||||
@ -1250,7 +1278,7 @@ XSLoader, DOMConfiguration {
|
||||
*/
|
||||
public DOMStringList getParameterNames() {
|
||||
if (fRecognizedParameters == null){
|
||||
Vector v = new Vector();
|
||||
ArrayList v = new ArrayList();
|
||||
v.add(Constants.DOM_VALIDATE);
|
||||
v.add(Constants.DOM_ERROR_HANDLER);
|
||||
v.add(Constants.DOM_RESOURCE_RESOLVER);
|
||||
@ -1391,4 +1419,13 @@ XSLoader, DOMConfiguration {
|
||||
return xis;
|
||||
}
|
||||
|
||||
// Implements XSElementDeclHelper interface
|
||||
public XSElementDecl getGlobalElementDecl(QName element) {
|
||||
SchemaGrammar sGrammar = fGrammarBucket.getGrammar(element.uri);
|
||||
if (sGrammar != null) {
|
||||
return sGrammar.getGlobalElementDecl(element.localpart);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
} // XMLGrammarLoader
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -32,6 +33,7 @@ import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNamespaceItem;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObjectList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSSimpleTypeDefinition;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSValue;
|
||||
|
||||
/**
|
||||
* The XML representation for an attribute declaration
|
||||
@ -211,4 +213,8 @@ public class XSAttributeDecl implements XSAttributeDeclaration {
|
||||
fDefault.itemValueTypes;
|
||||
}
|
||||
|
||||
public XSValue getValueConstraintValue() {
|
||||
return fDefault;
|
||||
}
|
||||
|
||||
} // class XSAttributeDecl
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 1999-2002,2004 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -28,6 +29,7 @@ import com.sun.org.apache.xerces.internal.xs.XSAttributeUse;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSConstants;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSNamespaceItem;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSObjectList;
|
||||
import com.sun.org.apache.xerces.internal.xs.XSValue;
|
||||
|
||||
/**
|
||||
* The XML representation for an attribute use
|
||||
@ -142,6 +144,10 @@ public class XSAttributeUseImpl implements XSAttributeUse {
|
||||
fDefault.itemValueTypes;
|
||||
}
|
||||
|
||||
public XSValue getValueConstraintValue() {
|
||||
return fDefault;
|
||||
}
|
||||
|
||||
/**
|
||||
* Optional. Annotations.
|
||||
*/
|
||||
|
@ -3,11 +3,12 @@
|
||||
* DO NOT REMOVE OR ALTER!
|
||||
*/
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
@ -77,7 +78,7 @@ public class XSComplexTypeDecl implements XSComplexTypeDefinition, TypeInfo {
|
||||
volatile XSCMValidator fCMValidator = null;
|
||||
|
||||
// the content model that's sufficient for computing UPA
|
||||
XSCMValidator fUPACMValidator = null;
|
||||
volatile XSCMValidator fUPACMValidator = null;
|
||||
|
||||
// list of annotations affiliated with this type
|
||||
XSObjectListImpl fAnnotations = null;
|
||||
@ -165,12 +166,28 @@ public class XSComplexTypeDecl implements XSComplexTypeDefinition, TypeInfo {
|
||||
fContentType == XSComplexTypeDecl.CONTENTTYPE_EMPTY) {
|
||||
return null;
|
||||
}
|
||||
if (fCMValidator == null)
|
||||
synchronized (this) {
|
||||
if (fCMValidator == null) {
|
||||
fCMValidator = cmBuilder.getContentModel(this);
|
||||
if (fCMValidator == null) {
|
||||
fCMValidator = getContentModel(cmBuilder, false);
|
||||
}
|
||||
return fCMValidator;
|
||||
}
|
||||
|
||||
public synchronized XSCMValidator getContentModel(CMBuilder cmBuilder, boolean forUPA) {
|
||||
if (fCMValidator == null) {
|
||||
if (forUPA) {
|
||||
if (fUPACMValidator == null) {
|
||||
fUPACMValidator = cmBuilder.getContentModel(this, true);
|
||||
|
||||
if (fUPACMValidator != null && !fUPACMValidator.isCompactedForUPA()) {
|
||||
fCMValidator = fUPACMValidator;
|
||||
}
|
||||
}
|
||||
return fUPACMValidator;
|
||||
}
|
||||
else {
|
||||
fCMValidator = cmBuilder.getContentModel(this, false);
|
||||
}
|
||||
}
|
||||
return fCMValidator;
|
||||
}
|
||||
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user