Merge
This commit is contained in:
commit
1816508a22
@ -160,3 +160,4 @@ cc771d92284f71765eca14d6d08703c4af254c04 jdk8-b21
|
|||||||
6a6ba0a07f33d37a2f97b1107e60c6a9a69ec84d jdk8-b36
|
6a6ba0a07f33d37a2f97b1107e60c6a9a69ec84d jdk8-b36
|
||||||
b2972095a4b1e2a97409b7c3df61f3b263a5ce14 jdk8-b37
|
b2972095a4b1e2a97409b7c3df61f3b263a5ce14 jdk8-b37
|
||||||
d939bd0ab13c16647ffa38cc4b64fb31b7d44e10 jdk8-b38
|
d939bd0ab13c16647ffa38cc4b64fb31b7d44e10 jdk8-b38
|
||||||
|
8927dd68aee3fa54a1a698e2980e1b2f6c7c12c1 jdk8-b39
|
||||||
|
@ -160,3 +160,4 @@ e3d735914edd0a621b16bb85417423f8e6af5d51 jdk8-b35
|
|||||||
a5a61f259961a7f46b002e5cc50b4a9bf86927b6 jdk8-b36
|
a5a61f259961a7f46b002e5cc50b4a9bf86927b6 jdk8-b36
|
||||||
83fac66442cf680bb59ec9e3a71cc4729322b595 jdk8-b37
|
83fac66442cf680bb59ec9e3a71cc4729322b595 jdk8-b37
|
||||||
b8cbfb31139f820e5e094ba71449e58159fbe22e jdk8-b38
|
b8cbfb31139f820e5e094ba71449e58159fbe22e jdk8-b38
|
||||||
|
785af00e2827990f149b32ec37f523dbca3efdd1 jdk8-b39
|
||||||
|
@ -246,3 +246,5 @@ bfcf92bfefb82da00f7fdbf0d9273feaa0a9456d jdk8-b37
|
|||||||
7d5ec8bf38d1b12e0e09ec381f10976b8beede3b hs24-b09
|
7d5ec8bf38d1b12e0e09ec381f10976b8beede3b hs24-b09
|
||||||
637c3f5f068f88fb9ec9c5867341cf59fd5ebedc jdk8-b38
|
637c3f5f068f88fb9ec9c5867341cf59fd5ebedc jdk8-b38
|
||||||
73147e6c48813b5fee904aa33f79a77103250ff4 hs24-b10
|
73147e6c48813b5fee904aa33f79a77103250ff4 hs24-b10
|
||||||
|
96a403721094ecdaf6a1f4f52ebd0a82e07df199 jdk8-b39
|
||||||
|
14b0e07ab9a6fa1662414496b7e07ac8450cf517 hs24-b11
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2006, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,11 +31,11 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
# Don't put quotes (fail windows build).
|
# Don't put quotes (fail windows build).
|
||||||
HOTSPOT_VM_COPYRIGHT=Copyright 2011
|
HOTSPOT_VM_COPYRIGHT=Copyright 2012
|
||||||
|
|
||||||
HS_MAJOR_VER=24
|
HS_MAJOR_VER=24
|
||||||
HS_MINOR_VER=0
|
HS_MINOR_VER=0
|
||||||
HS_BUILD_NUMBER=10
|
HS_BUILD_NUMBER=11
|
||||||
|
|
||||||
JDK_MAJOR_VER=1
|
JDK_MAJOR_VER=1
|
||||||
JDK_MINOR_VER=8
|
JDK_MINOR_VER=8
|
||||||
|
@ -103,8 +103,10 @@ CXXFLAGS = \
|
|||||||
vm_version.o: CXXFLAGS += ${JRE_VERSION}
|
vm_version.o: CXXFLAGS += ${JRE_VERSION}
|
||||||
|
|
||||||
ifndef JAVASE_EMBEDDED
|
ifndef JAVASE_EMBEDDED
|
||||||
|
ifneq (${ARCH},arm)
|
||||||
CFLAGS += -DINCLUDE_TRACE
|
CFLAGS += -DINCLUDE_TRACE
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# CFLAGS_WARN holds compiler options to suppress/enable warnings.
|
# CFLAGS_WARN holds compiler options to suppress/enable warnings.
|
||||||
CFLAGS += $(CFLAGS_WARN/BYFILE)
|
CFLAGS += $(CFLAGS_WARN/BYFILE)
|
||||||
@ -154,10 +156,12 @@ SOURCE_PATHS+=$(HS_COMMON_SRC)/cpu/$(Platform_arch)/vm
|
|||||||
SOURCE_PATHS+=$(HS_COMMON_SRC)/os_cpu/$(Platform_os_arch)/vm
|
SOURCE_PATHS+=$(HS_COMMON_SRC)/os_cpu/$(Platform_os_arch)/vm
|
||||||
|
|
||||||
ifndef JAVASE_EMBEDDED
|
ifndef JAVASE_EMBEDDED
|
||||||
|
ifneq (${ARCH},arm)
|
||||||
SOURCE_PATHS+=$(shell if [ -d $(HS_ALT_SRC)/share/vm/jfr ]; then \
|
SOURCE_PATHS+=$(shell if [ -d $(HS_ALT_SRC)/share/vm/jfr ]; then \
|
||||||
find $(HS_ALT_SRC)/share/vm/jfr -type d; \
|
find $(HS_ALT_SRC)/share/vm/jfr -type d; \
|
||||||
fi)
|
fi)
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
CORE_PATHS=$(foreach path,$(SOURCE_PATHS),$(call altsrc,$(path)) $(path))
|
CORE_PATHS=$(foreach path,$(SOURCE_PATHS),$(call altsrc,$(path)) $(path))
|
||||||
CORE_PATHS+=$(GENERATED)/jvmtifiles
|
CORE_PATHS+=$(GENERATED)/jvmtifiles
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -238,9 +238,12 @@ void LIR_Assembler::emit_string_compare(LIR_Opr left, LIR_Opr right, LIR_Opr dst
|
|||||||
|
|
||||||
Register result = dst->as_register();
|
Register result = dst->as_register();
|
||||||
{
|
{
|
||||||
// Get a pointer to the first character of string0 in tmp0 and get string0.count in str0
|
// Get a pointer to the first character of string0 in tmp0
|
||||||
// Get a pointer to the first character of string1 in tmp1 and get string1.count in str1
|
// and get string0.length() in str0
|
||||||
// Also, get string0.count-string1.count in o7 and get the condition code set
|
// Get a pointer to the first character of string1 in tmp1
|
||||||
|
// and get string1.length() in str1
|
||||||
|
// Also, get string0.length()-string1.length() in
|
||||||
|
// o7 and get the condition code set
|
||||||
// Note: some instructions have been hoisted for better instruction scheduling
|
// Note: some instructions have been hoisted for better instruction scheduling
|
||||||
|
|
||||||
Register tmp0 = L0;
|
Register tmp0 = L0;
|
||||||
@ -248,27 +251,40 @@ void LIR_Assembler::emit_string_compare(LIR_Opr left, LIR_Opr right, LIR_Opr dst
|
|||||||
Register tmp2 = L2;
|
Register tmp2 = L2;
|
||||||
|
|
||||||
int value_offset = java_lang_String:: value_offset_in_bytes(); // char array
|
int value_offset = java_lang_String:: value_offset_in_bytes(); // char array
|
||||||
int offset_offset = java_lang_String::offset_offset_in_bytes(); // first character position
|
if (java_lang_String::has_offset_field()) {
|
||||||
int count_offset = java_lang_String:: count_offset_in_bytes();
|
int offset_offset = java_lang_String::offset_offset_in_bytes(); // first character position
|
||||||
|
int count_offset = java_lang_String:: count_offset_in_bytes();
|
||||||
__ load_heap_oop(str0, value_offset, tmp0);
|
__ load_heap_oop(str0, value_offset, tmp0);
|
||||||
__ ld(str0, offset_offset, tmp2);
|
__ ld(str0, offset_offset, tmp2);
|
||||||
__ add(tmp0, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp0);
|
__ add(tmp0, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp0);
|
||||||
__ ld(str0, count_offset, str0);
|
__ ld(str0, count_offset, str0);
|
||||||
__ sll(tmp2, exact_log2(sizeof(jchar)), tmp2);
|
__ sll(tmp2, exact_log2(sizeof(jchar)), tmp2);
|
||||||
|
} else {
|
||||||
|
__ load_heap_oop(str0, value_offset, tmp1);
|
||||||
|
__ add(tmp1, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp0);
|
||||||
|
__ ld(tmp1, arrayOopDesc::length_offset_in_bytes(), str0);
|
||||||
|
}
|
||||||
|
|
||||||
// str1 may be null
|
// str1 may be null
|
||||||
add_debug_info_for_null_check_here(info);
|
add_debug_info_for_null_check_here(info);
|
||||||
|
|
||||||
__ load_heap_oop(str1, value_offset, tmp1);
|
if (java_lang_String::has_offset_field()) {
|
||||||
__ add(tmp0, tmp2, tmp0);
|
int offset_offset = java_lang_String::offset_offset_in_bytes(); // first character position
|
||||||
|
int count_offset = java_lang_String:: count_offset_in_bytes();
|
||||||
|
__ load_heap_oop(str1, value_offset, tmp1);
|
||||||
|
__ add(tmp0, tmp2, tmp0);
|
||||||
|
|
||||||
__ ld(str1, offset_offset, tmp2);
|
__ ld(str1, offset_offset, tmp2);
|
||||||
__ add(tmp1, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp1);
|
__ add(tmp1, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp1);
|
||||||
__ ld(str1, count_offset, str1);
|
__ ld(str1, count_offset, str1);
|
||||||
__ sll(tmp2, exact_log2(sizeof(jchar)), tmp2);
|
__ sll(tmp2, exact_log2(sizeof(jchar)), tmp2);
|
||||||
|
__ add(tmp1, tmp2, tmp1);
|
||||||
|
} else {
|
||||||
|
__ load_heap_oop(str1, value_offset, tmp2);
|
||||||
|
__ add(tmp2, arrayOopDesc::base_offset_in_bytes(T_CHAR), tmp1);
|
||||||
|
__ ld(tmp2, arrayOopDesc::length_offset_in_bytes(), str1);
|
||||||
|
}
|
||||||
__ subcc(str0, str1, O7);
|
__ subcc(str0, str1, O7);
|
||||||
__ add(tmp1, tmp2, tmp1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -302,7 +318,7 @@ void LIR_Assembler::emit_string_compare(LIR_Opr left, LIR_Opr right, LIR_Opr dst
|
|||||||
// Shift base0 and base1 to the end of the arrays, negate limit
|
// Shift base0 and base1 to the end of the arrays, negate limit
|
||||||
__ add(base0, limit, base0);
|
__ add(base0, limit, base0);
|
||||||
__ add(base1, limit, base1);
|
__ add(base1, limit, base1);
|
||||||
__ neg(limit); // limit = -min{string0.count, strin1.count}
|
__ neg(limit); // limit = -min{string0.length(), string1.length()}
|
||||||
|
|
||||||
__ lduh(base0, limit, chr0);
|
__ lduh(base0, limit, chr0);
|
||||||
__ bind(Lloop);
|
__ bind(Lloop);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -505,19 +505,28 @@ void LIR_Assembler::emit_string_compare(LIR_Opr arg0, LIR_Opr arg1, LIR_Opr dst,
|
|||||||
|
|
||||||
// Get addresses of first characters from both Strings
|
// Get addresses of first characters from both Strings
|
||||||
__ load_heap_oop(rsi, Address(rax, java_lang_String::value_offset_in_bytes()));
|
__ load_heap_oop(rsi, Address(rax, java_lang_String::value_offset_in_bytes()));
|
||||||
__ movptr (rcx, Address(rax, java_lang_String::offset_offset_in_bytes()));
|
if (java_lang_String::has_offset_field()) {
|
||||||
__ lea (rsi, Address(rsi, rcx, Address::times_2, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
__ movptr (rcx, Address(rax, java_lang_String::offset_offset_in_bytes()));
|
||||||
|
__ movl (rax, Address(rax, java_lang_String::count_offset_in_bytes()));
|
||||||
|
__ lea (rsi, Address(rsi, rcx, Address::times_2, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
||||||
|
} else {
|
||||||
|
__ movl (rax, Address(rsi, arrayOopDesc::length_offset_in_bytes()));
|
||||||
|
__ lea (rsi, Address(rsi, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
||||||
|
}
|
||||||
|
|
||||||
// rbx, may be NULL
|
// rbx, may be NULL
|
||||||
add_debug_info_for_null_check_here(info);
|
add_debug_info_for_null_check_here(info);
|
||||||
__ load_heap_oop(rdi, Address(rbx, java_lang_String::value_offset_in_bytes()));
|
__ load_heap_oop(rdi, Address(rbx, java_lang_String::value_offset_in_bytes()));
|
||||||
__ movptr (rcx, Address(rbx, java_lang_String::offset_offset_in_bytes()));
|
if (java_lang_String::has_offset_field()) {
|
||||||
__ lea (rdi, Address(rdi, rcx, Address::times_2, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
__ movptr (rcx, Address(rbx, java_lang_String::offset_offset_in_bytes()));
|
||||||
|
__ movl (rbx, Address(rbx, java_lang_String::count_offset_in_bytes()));
|
||||||
|
__ lea (rdi, Address(rdi, rcx, Address::times_2, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
||||||
|
} else {
|
||||||
|
__ movl (rbx, Address(rdi, arrayOopDesc::length_offset_in_bytes()));
|
||||||
|
__ lea (rdi, Address(rdi, arrayOopDesc::base_offset_in_bytes(T_CHAR)));
|
||||||
|
}
|
||||||
|
|
||||||
// compute minimum length (in rax) and difference of lengths (on top of stack)
|
// compute minimum length (in rax) and difference of lengths (on top of stack)
|
||||||
__ movl (rbx, Address(rbx, java_lang_String::count_offset_in_bytes()));
|
|
||||||
__ movl (rax, Address(rax, java_lang_String::count_offset_in_bytes()));
|
|
||||||
__ mov (rcx, rbx);
|
__ mov (rcx, rbx);
|
||||||
__ subptr(rbx, rax); // subtract lengths
|
__ subptr(rbx, rax); // subtract lengths
|
||||||
__ push (rbx); // result
|
__ push (rbx); // result
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -143,7 +143,27 @@ compute_optional_offset(int& dest_offset,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int java_lang_String::value_offset = 0;
|
||||||
|
int java_lang_String::offset_offset = 0;
|
||||||
|
int java_lang_String::count_offset = 0;
|
||||||
|
int java_lang_String::hash_offset = 0;
|
||||||
|
|
||||||
|
bool java_lang_String::initialized = false;
|
||||||
|
|
||||||
|
void java_lang_String::compute_offsets() {
|
||||||
|
assert(!initialized, "offsets should be initialized only once");
|
||||||
|
|
||||||
|
klassOop k = SystemDictionary::String_klass();
|
||||||
|
compute_offset(value_offset, k, vmSymbols::value_name(), vmSymbols::char_array_signature());
|
||||||
|
compute_optional_offset(offset_offset, k, vmSymbols::offset_name(), vmSymbols::int_signature());
|
||||||
|
compute_optional_offset(count_offset, k, vmSymbols::count_name(), vmSymbols::int_signature());
|
||||||
|
compute_optional_offset(hash_offset, k, vmSymbols::hash_name(), vmSymbols::int_signature());
|
||||||
|
|
||||||
|
initialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
Handle java_lang_String::basic_create(int length, bool tenured, TRAPS) {
|
Handle java_lang_String::basic_create(int length, bool tenured, TRAPS) {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
// Create the String object first, so there's a chance that the String
|
// Create the String object first, so there's a chance that the String
|
||||||
// and the char array it points to end up in the same cache line.
|
// and the char array it points to end up in the same cache line.
|
||||||
oop obj;
|
oop obj;
|
||||||
@ -2837,10 +2857,6 @@ int java_lang_System::err_offset_in_bytes() {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
int java_lang_String::value_offset;
|
|
||||||
int java_lang_String::offset_offset;
|
|
||||||
int java_lang_String::count_offset;
|
|
||||||
int java_lang_String::hash_offset;
|
|
||||||
int java_lang_Class::_klass_offset;
|
int java_lang_Class::_klass_offset;
|
||||||
int java_lang_Class::_array_klass_offset;
|
int java_lang_Class::_array_klass_offset;
|
||||||
int java_lang_Class::_resolved_constructor_offset;
|
int java_lang_Class::_resolved_constructor_offset;
|
||||||
@ -3000,12 +3016,6 @@ void JavaClasses::compute_hard_coded_offsets() {
|
|||||||
const int x = heapOopSize;
|
const int x = heapOopSize;
|
||||||
const int header = instanceOopDesc::base_offset_in_bytes();
|
const int header = instanceOopDesc::base_offset_in_bytes();
|
||||||
|
|
||||||
// Do the String Class
|
|
||||||
java_lang_String::value_offset = java_lang_String::hc_value_offset * x + header;
|
|
||||||
java_lang_String::offset_offset = java_lang_String::hc_offset_offset * x + header;
|
|
||||||
java_lang_String::count_offset = java_lang_String::offset_offset + sizeof (jint);
|
|
||||||
java_lang_String::hash_offset = java_lang_String::count_offset + sizeof (jint);
|
|
||||||
|
|
||||||
// Throwable Class
|
// Throwable Class
|
||||||
java_lang_Throwable::backtrace_offset = java_lang_Throwable::hc_backtrace_offset * x + header;
|
java_lang_Throwable::backtrace_offset = java_lang_Throwable::hc_backtrace_offset * x + header;
|
||||||
java_lang_Throwable::detailMessage_offset = java_lang_Throwable::hc_detailMessage_offset * x + header;
|
java_lang_Throwable::detailMessage_offset = java_lang_Throwable::hc_detailMessage_offset * x + header;
|
||||||
@ -3200,9 +3210,13 @@ void JavaClasses::check_offsets() {
|
|||||||
// java.lang.String
|
// java.lang.String
|
||||||
|
|
||||||
CHECK_OFFSET("java/lang/String", java_lang_String, value, "[C");
|
CHECK_OFFSET("java/lang/String", java_lang_String, value, "[C");
|
||||||
CHECK_OFFSET("java/lang/String", java_lang_String, offset, "I");
|
if (java_lang_String::has_offset_field()) {
|
||||||
CHECK_OFFSET("java/lang/String", java_lang_String, count, "I");
|
CHECK_OFFSET("java/lang/String", java_lang_String, offset, "I");
|
||||||
CHECK_OFFSET("java/lang/String", java_lang_String, hash, "I");
|
CHECK_OFFSET("java/lang/String", java_lang_String, count, "I");
|
||||||
|
}
|
||||||
|
if (java_lang_String::has_hash_field()) {
|
||||||
|
CHECK_OFFSET("java/lang/String", java_lang_String, hash, "I");
|
||||||
|
}
|
||||||
|
|
||||||
// java.lang.Class
|
// java.lang.Class
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -52,26 +52,36 @@
|
|||||||
|
|
||||||
class java_lang_String : AllStatic {
|
class java_lang_String : AllStatic {
|
||||||
private:
|
private:
|
||||||
enum {
|
|
||||||
hc_value_offset = 0,
|
|
||||||
hc_offset_offset = 1
|
|
||||||
//hc_count_offset = 2 -- not a word-scaled offset
|
|
||||||
//hc_hash_offset = 3 -- not a word-scaled offset
|
|
||||||
};
|
|
||||||
|
|
||||||
static int value_offset;
|
static int value_offset;
|
||||||
static int offset_offset;
|
static int offset_offset;
|
||||||
static int count_offset;
|
static int count_offset;
|
||||||
static int hash_offset;
|
static int hash_offset;
|
||||||
|
|
||||||
|
static bool initialized;
|
||||||
|
|
||||||
static Handle basic_create(int length, bool tenured, TRAPS);
|
static Handle basic_create(int length, bool tenured, TRAPS);
|
||||||
static Handle basic_create_from_unicode(jchar* unicode, int length, bool tenured, TRAPS);
|
static Handle basic_create_from_unicode(jchar* unicode, int length, bool tenured, TRAPS);
|
||||||
|
|
||||||
static void set_value( oop string, typeArrayOop buffer) { string->obj_field_put(value_offset, (oop)buffer); }
|
static void set_value( oop string, typeArrayOop buffer) {
|
||||||
static void set_offset(oop string, int offset) { string->int_field_put(offset_offset, offset); }
|
assert(initialized, "Must be initialized");
|
||||||
static void set_count( oop string, int count) { string->int_field_put(count_offset, count); }
|
string->obj_field_put(value_offset, (oop)buffer);
|
||||||
|
}
|
||||||
|
static void set_offset(oop string, int offset) {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
|
if (offset_offset > 0) {
|
||||||
|
string->int_field_put(offset_offset, offset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
static void set_count( oop string, int count) {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
|
if (count_offset > 0) {
|
||||||
|
string->int_field_put(count_offset, count);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
static void compute_offsets();
|
||||||
|
|
||||||
// Instance creation
|
// Instance creation
|
||||||
static Handle create_from_unicode(jchar* unicode, int len, TRAPS);
|
static Handle create_from_unicode(jchar* unicode, int len, TRAPS);
|
||||||
static Handle create_tenured_from_unicode(jchar* unicode, int len, TRAPS);
|
static Handle create_tenured_from_unicode(jchar* unicode, int len, TRAPS);
|
||||||
@ -82,23 +92,61 @@ class java_lang_String : AllStatic {
|
|||||||
static Handle create_from_platform_dependent_str(const char* str, TRAPS);
|
static Handle create_from_platform_dependent_str(const char* str, TRAPS);
|
||||||
static Handle char_converter(Handle java_string, jchar from_char, jchar to_char, TRAPS);
|
static Handle char_converter(Handle java_string, jchar from_char, jchar to_char, TRAPS);
|
||||||
|
|
||||||
static int value_offset_in_bytes() { return value_offset; }
|
static bool has_offset_field() {
|
||||||
static int count_offset_in_bytes() { return count_offset; }
|
assert(initialized, "Must be initialized");
|
||||||
static int offset_offset_in_bytes() { return offset_offset; }
|
return (offset_offset > 0);
|
||||||
static int hash_offset_in_bytes() { return hash_offset; }
|
}
|
||||||
|
|
||||||
|
static bool has_count_field() {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
|
return (count_offset > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool has_hash_field() {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
|
return (hash_offset > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int value_offset_in_bytes() {
|
||||||
|
assert(initialized && (value_offset > 0), "Must be initialized");
|
||||||
|
return value_offset;
|
||||||
|
}
|
||||||
|
static int count_offset_in_bytes() {
|
||||||
|
assert(initialized && (count_offset > 0), "Must be initialized");
|
||||||
|
return count_offset;
|
||||||
|
}
|
||||||
|
static int offset_offset_in_bytes() {
|
||||||
|
assert(initialized && (offset_offset > 0), "Must be initialized");
|
||||||
|
return offset_offset;
|
||||||
|
}
|
||||||
|
static int hash_offset_in_bytes() {
|
||||||
|
assert(initialized && (hash_offset > 0), "Must be initialized");
|
||||||
|
return hash_offset;
|
||||||
|
}
|
||||||
|
|
||||||
// Accessors
|
// Accessors
|
||||||
static typeArrayOop value(oop java_string) {
|
static typeArrayOop value(oop java_string) {
|
||||||
|
assert(initialized && (value_offset > 0), "Must be initialized");
|
||||||
assert(is_instance(java_string), "must be java_string");
|
assert(is_instance(java_string), "must be java_string");
|
||||||
return (typeArrayOop) java_string->obj_field(value_offset);
|
return (typeArrayOop) java_string->obj_field(value_offset);
|
||||||
}
|
}
|
||||||
static int offset(oop java_string) {
|
static int offset(oop java_string) {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
assert(is_instance(java_string), "must be java_string");
|
assert(is_instance(java_string), "must be java_string");
|
||||||
return java_string->int_field(offset_offset);
|
if (offset_offset > 0) {
|
||||||
|
return java_string->int_field(offset_offset);
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
static int length(oop java_string) {
|
static int length(oop java_string) {
|
||||||
|
assert(initialized, "Must be initialized");
|
||||||
assert(is_instance(java_string), "must be java_string");
|
assert(is_instance(java_string), "must be java_string");
|
||||||
return java_string->int_field(count_offset);
|
if (count_offset > 0) {
|
||||||
|
return java_string->int_field(count_offset);
|
||||||
|
} else {
|
||||||
|
return ((typeArrayOop)java_string->obj_field(value_offset))->length();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
static int utf8_length(oop java_string);
|
static int utf8_length(oop java_string);
|
||||||
|
|
||||||
|
@ -1971,6 +1971,9 @@ void SystemDictionary::initialize_preloaded_classes(TRAPS) {
|
|||||||
// first do Object, String, Class
|
// first do Object, String, Class
|
||||||
initialize_wk_klasses_through(WK_KLASS_ENUM_NAME(Class_klass), scan, CHECK);
|
initialize_wk_klasses_through(WK_KLASS_ENUM_NAME(Class_klass), scan, CHECK);
|
||||||
|
|
||||||
|
// Calculate offsets for String and Class classes since they are loaded and
|
||||||
|
// can be used after this point.
|
||||||
|
java_lang_String::compute_offsets();
|
||||||
java_lang_Class::compute_offsets();
|
java_lang_Class::compute_offsets();
|
||||||
|
|
||||||
// Fixup mirrors for classes loaded before java.lang.Class.
|
// Fixup mirrors for classes loaded before java.lang.Class.
|
||||||
|
@ -340,6 +340,9 @@
|
|||||||
template(park_event_name, "nativeParkEventPointer") \
|
template(park_event_name, "nativeParkEventPointer") \
|
||||||
template(cache_field_name, "cache") \
|
template(cache_field_name, "cache") \
|
||||||
template(value_name, "value") \
|
template(value_name, "value") \
|
||||||
|
template(offset_name, "offset") \
|
||||||
|
template(count_name, "count") \
|
||||||
|
template(hash_name, "hash") \
|
||||||
template(frontCacheEnabled_name, "frontCacheEnabled") \
|
template(frontCacheEnabled_name, "frontCacheEnabled") \
|
||||||
template(stringCacheEnabled_name, "stringCacheEnabled") \
|
template(stringCacheEnabled_name, "stringCacheEnabled") \
|
||||||
template(numberOfLeadingZeros_name, "numberOfLeadingZeros") \
|
template(numberOfLeadingZeros_name, "numberOfLeadingZeros") \
|
||||||
|
@ -6332,10 +6332,10 @@ void CMSCollector::reset(bool asynch) {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
void CMSCollector::do_CMS_operation(CMS_op_type op) {
|
void CMSCollector::do_CMS_operation(CMS_op_type op, GCCause::Cause gc_cause) {
|
||||||
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
||||||
TraceTime t("GC", PrintGC, !PrintGCDetails, gclog_or_tty);
|
TraceTime t(GCCauseString("GC", gc_cause), PrintGC, !PrintGCDetails, gclog_or_tty);
|
||||||
TraceCollectorStats tcs(counters());
|
TraceCollectorStats tcs(counters());
|
||||||
|
|
||||||
switch (op) {
|
switch (op) {
|
||||||
|
@ -717,7 +717,7 @@ class CMSCollector: public CHeapObj {
|
|||||||
CMS_op_checkpointRootsFinal
|
CMS_op_checkpointRootsFinal
|
||||||
};
|
};
|
||||||
|
|
||||||
void do_CMS_operation(CMS_op_type op);
|
void do_CMS_operation(CMS_op_type op, GCCause::Cause gc_cause);
|
||||||
bool stop_world_and_do(CMS_op_type op);
|
bool stop_world_and_do(CMS_op_type op);
|
||||||
|
|
||||||
OopTaskQueueSet* task_queues() { return _task_queues; }
|
OopTaskQueueSet* task_queues() { return _task_queues; }
|
||||||
|
@ -146,7 +146,7 @@ void VM_CMS_Initial_Mark::doit() {
|
|||||||
VM_CMS_Operation::verify_before_gc();
|
VM_CMS_Operation::verify_before_gc();
|
||||||
|
|
||||||
IsGCActiveMark x; // stop-world GC active
|
IsGCActiveMark x; // stop-world GC active
|
||||||
_collector->do_CMS_operation(CMSCollector::CMS_op_checkpointRootsInitial);
|
_collector->do_CMS_operation(CMSCollector::CMS_op_checkpointRootsInitial, gch->gc_cause());
|
||||||
|
|
||||||
VM_CMS_Operation::verify_after_gc();
|
VM_CMS_Operation::verify_after_gc();
|
||||||
#ifndef USDT2
|
#ifndef USDT2
|
||||||
@ -178,7 +178,7 @@ void VM_CMS_Final_Remark::doit() {
|
|||||||
VM_CMS_Operation::verify_before_gc();
|
VM_CMS_Operation::verify_before_gc();
|
||||||
|
|
||||||
IsGCActiveMark x; // stop-world GC active
|
IsGCActiveMark x; // stop-world GC active
|
||||||
_collector->do_CMS_operation(CMSCollector::CMS_op_checkpointRootsFinal);
|
_collector->do_CMS_operation(CMSCollector::CMS_op_checkpointRootsFinal, gch->gc_cause());
|
||||||
|
|
||||||
VM_CMS_Operation::verify_after_gc();
|
VM_CMS_Operation::verify_after_gc();
|
||||||
#ifndef USDT2
|
#ifndef USDT2
|
||||||
|
@ -1252,10 +1252,7 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
|
|||||||
gclog_or_tty->date_stamp(G1Log::fine() && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(G1Log::fine() && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(G1Log::finer(), true, gclog_or_tty);
|
TraceCPUTime tcpu(G1Log::finer(), true, gclog_or_tty);
|
||||||
|
|
||||||
char verbose_str[128];
|
TraceTime t(GCCauseString("Full GC", gc_cause()), G1Log::fine(), true, gclog_or_tty);
|
||||||
sprintf(verbose_str, "Full GC (%s)", GCCause::to_string(gc_cause()));
|
|
||||||
TraceTime t(verbose_str, G1Log::fine(), true, gclog_or_tty);
|
|
||||||
|
|
||||||
TraceCollectorStats tcs(g1mm()->full_collection_counters());
|
TraceCollectorStats tcs(g1mm()->full_collection_counters());
|
||||||
TraceMemoryManagerStats tms(true /* fullGC */, gc_cause());
|
TraceMemoryManagerStats tms(true /* fullGC */, gc_cause());
|
||||||
|
|
||||||
@ -3600,12 +3597,10 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
|
|||||||
gclog_or_tty->date_stamp(G1Log::fine() && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(G1Log::fine() && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(G1Log::finer(), true, gclog_or_tty);
|
TraceCPUTime tcpu(G1Log::finer(), true, gclog_or_tty);
|
||||||
|
|
||||||
char verbose_str[128];
|
GCCauseString gc_cause_str = GCCauseString("GC pause", gc_cause())
|
||||||
sprintf(verbose_str, "GC pause (%s) (%s)%s",
|
.append(g1_policy()->gcs_are_young() ? " (young)" : " (mixed)")
|
||||||
GCCause::to_string(gc_cause()),
|
.append(g1_policy()->during_initial_mark_pause() ? " (initial-mark)" : "");
|
||||||
g1_policy()->gcs_are_young() ? "young" : "mixed",
|
TraceTime t(gc_cause_str, G1Log::fine() && !G1Log::finer(), true, gclog_or_tty);
|
||||||
g1_policy()->during_initial_mark_pause() ? " (initial-mark)" : "");
|
|
||||||
TraceTime t(verbose_str, G1Log::fine() && !G1Log::finer(), true, gclog_or_tty);
|
|
||||||
|
|
||||||
TraceCollectorStats tcs(g1mm()->incremental_collection_counters());
|
TraceCollectorStats tcs(g1mm()->incremental_collection_counters());
|
||||||
TraceMemoryManagerStats tms(false /* fullGC */, gc_cause());
|
TraceMemoryManagerStats tms(false /* fullGC */, gc_cause());
|
||||||
@ -5502,7 +5497,7 @@ void G1CollectedHeap::evacuate_collection_set() {
|
|||||||
if (evacuation_failed()) {
|
if (evacuation_failed()) {
|
||||||
remove_self_forwarding_pointers();
|
remove_self_forwarding_pointers();
|
||||||
if (G1Log::finer()) {
|
if (G1Log::finer()) {
|
||||||
gclog_or_tty->print(" (to-space overflow)");
|
gclog_or_tty->print(" (to-space exhausted)");
|
||||||
} else if (G1Log::fine()) {
|
} else if (G1Log::fine()) {
|
||||||
gclog_or_tty->print("--");
|
gclog_or_tty->print("--");
|
||||||
}
|
}
|
||||||
|
@ -886,9 +886,8 @@ void G1CollectorPolicy::record_collection_pause_start(double start_time_sec,
|
|||||||
size_t start_used) {
|
size_t start_used) {
|
||||||
if (G1Log::finer()) {
|
if (G1Log::finer()) {
|
||||||
gclog_or_tty->stamp(PrintGCTimeStamps);
|
gclog_or_tty->stamp(PrintGCTimeStamps);
|
||||||
gclog_or_tty->print("[GC pause (%s) (%s)",
|
gclog_or_tty->print("[%s", (const char*)GCCauseString("GC pause", _g1->gc_cause())
|
||||||
GCCause::to_string(_g1->gc_cause()),
|
.append(gcs_are_young() ? " (young)" : " (mixed)"));
|
||||||
gcs_are_young() ? "young" : "mixed");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// We only need to do this here as the policy will only be applied
|
// We only need to do this here as the policy will only be applied
|
||||||
@ -1010,7 +1009,8 @@ T sum_of(T* sum_arr, int start, int n, int N) {
|
|||||||
|
|
||||||
void G1CollectorPolicy::print_par_stats(int level,
|
void G1CollectorPolicy::print_par_stats(int level,
|
||||||
const char* str,
|
const char* str,
|
||||||
double* data) {
|
double* data,
|
||||||
|
bool showDecimals) {
|
||||||
double min = data[0], max = data[0];
|
double min = data[0], max = data[0];
|
||||||
double total = 0.0;
|
double total = 0.0;
|
||||||
LineBuffer buf(level);
|
LineBuffer buf(level);
|
||||||
@ -1023,7 +1023,11 @@ void G1CollectorPolicy::print_par_stats(int level,
|
|||||||
max = val;
|
max = val;
|
||||||
total += val;
|
total += val;
|
||||||
if (G1Log::finest()) {
|
if (G1Log::finest()) {
|
||||||
buf.append(" %.1lf", val);
|
if (showDecimals) {
|
||||||
|
buf.append(" %.1lf", val);
|
||||||
|
} else {
|
||||||
|
buf.append(" %d", (int)val);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1031,36 +1035,26 @@ void G1CollectorPolicy::print_par_stats(int level,
|
|||||||
buf.append_and_print_cr("");
|
buf.append_and_print_cr("");
|
||||||
}
|
}
|
||||||
double avg = total / (double) no_of_gc_threads();
|
double avg = total / (double) no_of_gc_threads();
|
||||||
buf.append_and_print_cr(" Avg: %.1lf Min: %.1lf Max: %.1lf Diff: %.1lf]",
|
if (showDecimals) {
|
||||||
avg, min, max, max - min);
|
buf.append_and_print_cr(" Min: %.1lf, Avg: %.1lf, Max: %.1lf, Diff: %.1lf, Sum: %.1lf]",
|
||||||
}
|
min, avg, max, max - min, total);
|
||||||
|
} else {
|
||||||
void G1CollectorPolicy::print_par_sizes(int level,
|
buf.append_and_print_cr(" Min: %d, Avg: %d, Max: %d, Diff: %d, Sum: %d]",
|
||||||
const char* str,
|
(int)min, (int)avg, (int)max, (int)max - (int)min, (int)total);
|
||||||
double* data) {
|
|
||||||
double min = data[0], max = data[0];
|
|
||||||
double total = 0.0;
|
|
||||||
LineBuffer buf(level);
|
|
||||||
buf.append("[%s :", str);
|
|
||||||
for (uint i = 0; i < no_of_gc_threads(); ++i) {
|
|
||||||
double val = data[i];
|
|
||||||
if (val < min)
|
|
||||||
min = val;
|
|
||||||
if (val > max)
|
|
||||||
max = val;
|
|
||||||
total += val;
|
|
||||||
buf.append(" %d", (int) val);
|
|
||||||
}
|
}
|
||||||
buf.append_and_print_cr("");
|
|
||||||
double avg = total / (double) no_of_gc_threads();
|
|
||||||
buf.append_and_print_cr(" Sum: %d, Avg: %d, Min: %d, Max: %d, Diff: %d]",
|
|
||||||
(int)total, (int)avg, (int)min, (int)max, (int)max - (int)min);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1CollectorPolicy::print_stats(int level,
|
void G1CollectorPolicy::print_stats(int level,
|
||||||
const char* str,
|
const char* str,
|
||||||
double value) {
|
double value) {
|
||||||
LineBuffer(level).append_and_print_cr("[%s: %5.1lf ms]", str, value);
|
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms]", str, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
void G1CollectorPolicy::print_stats(int level,
|
||||||
|
const char* str,
|
||||||
|
double value,
|
||||||
|
int workers) {
|
||||||
|
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms, GC Workers: %d]", str, value, workers);
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1CollectorPolicy::print_stats(int level,
|
void G1CollectorPolicy::print_stats(int level,
|
||||||
@ -1373,7 +1367,7 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
print_stats(1, "Root Region Scan Waiting", _root_region_scan_wait_time_ms);
|
print_stats(1, "Root Region Scan Waiting", _root_region_scan_wait_time_ms);
|
||||||
}
|
}
|
||||||
if (parallel) {
|
if (parallel) {
|
||||||
print_stats(1, "Parallel Time", _cur_collection_par_time_ms);
|
print_stats(1, "Parallel Time", _cur_collection_par_time_ms, no_of_gc_threads);
|
||||||
print_par_stats(2, "GC Worker Start", _par_last_gc_worker_start_times_ms);
|
print_par_stats(2, "GC Worker Start", _par_last_gc_worker_start_times_ms);
|
||||||
print_par_stats(2, "Ext Root Scanning", _par_last_ext_root_scan_times_ms);
|
print_par_stats(2, "Ext Root Scanning", _par_last_ext_root_scan_times_ms);
|
||||||
if (print_marking_info) {
|
if (print_marking_info) {
|
||||||
@ -1381,13 +1375,15 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
}
|
}
|
||||||
print_par_stats(2, "Update RS", _par_last_update_rs_times_ms);
|
print_par_stats(2, "Update RS", _par_last_update_rs_times_ms);
|
||||||
if (G1Log::finest()) {
|
if (G1Log::finest()) {
|
||||||
print_par_sizes(3, "Processed Buffers", _par_last_update_rs_processed_buffers);
|
print_par_stats(3, "Processed Buffers", _par_last_update_rs_processed_buffers,
|
||||||
|
false /* showDecimals */);
|
||||||
}
|
}
|
||||||
print_par_stats(2, "Scan RS", _par_last_scan_rs_times_ms);
|
print_par_stats(2, "Scan RS", _par_last_scan_rs_times_ms);
|
||||||
print_par_stats(2, "Object Copy", _par_last_obj_copy_times_ms);
|
print_par_stats(2, "Object Copy", _par_last_obj_copy_times_ms);
|
||||||
print_par_stats(2, "Termination", _par_last_termination_times_ms);
|
print_par_stats(2, "Termination", _par_last_termination_times_ms);
|
||||||
if (G1Log::finest()) {
|
if (G1Log::finest()) {
|
||||||
print_par_sizes(3, "Termination Attempts", _par_last_termination_attempts);
|
print_par_stats(3, "Termination Attempts", _par_last_termination_attempts,
|
||||||
|
false /* showDecimals */);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < _parallel_gc_threads; i++) {
|
for (int i = 0; i < _parallel_gc_threads; i++) {
|
||||||
@ -1601,9 +1597,9 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
_collectionSetChooser->verify();
|
_collectionSetChooser->verify();
|
||||||
}
|
}
|
||||||
|
|
||||||
#define EXT_SIZE_FORMAT "%d%s"
|
#define EXT_SIZE_FORMAT "%.1f%s"
|
||||||
#define EXT_SIZE_PARAMS(bytes) \
|
#define EXT_SIZE_PARAMS(bytes) \
|
||||||
byte_size_in_proper_unit((bytes)), \
|
byte_size_in_proper_unit((double)(bytes)), \
|
||||||
proper_unit_for_byte_size((bytes))
|
proper_unit_for_byte_size((bytes))
|
||||||
|
|
||||||
void G1CollectorPolicy::print_heap_transition() {
|
void G1CollectorPolicy::print_heap_transition() {
|
||||||
|
@ -552,10 +552,10 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
void print_stats(int level, const char* str, double value);
|
void print_stats(int level, const char* str, double value);
|
||||||
|
void print_stats(int level, const char* str, double value, int workers);
|
||||||
void print_stats(int level, const char* str, int value);
|
void print_stats(int level, const char* str, int value);
|
||||||
|
|
||||||
void print_par_stats(int level, const char* str, double* data);
|
void print_par_stats(int level, const char* str, double* data, bool showDecimals = true);
|
||||||
void print_par_sizes(int level, const char* str, double* data);
|
|
||||||
|
|
||||||
void check_other_times(int level,
|
void check_other_times(int level,
|
||||||
NumberSeq* other_times_ms,
|
NumberSeq* other_times_ms,
|
||||||
|
@ -42,6 +42,7 @@ VM_G1CollectForAllocation::VM_G1CollectForAllocation(
|
|||||||
|
|
||||||
void VM_G1CollectForAllocation::doit() {
|
void VM_G1CollectForAllocation::doit() {
|
||||||
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
||||||
|
GCCauseSetter x(g1h, _gc_cause);
|
||||||
_result = g1h->satisfy_failed_allocation(_word_size, &_pause_succeeded);
|
_result = g1h->satisfy_failed_allocation(_word_size, &_pause_succeeded);
|
||||||
assert(_result == NULL || _pause_succeeded,
|
assert(_result == NULL || _pause_succeeded,
|
||||||
"if we get back a result, the pause should have succeeded");
|
"if we get back a result, the pause should have succeeded");
|
||||||
|
@ -916,7 +916,7 @@ void ParNewGeneration::collect(bool full,
|
|||||||
size_policy->minor_collection_begin();
|
size_policy->minor_collection_begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
TraceTime t1("GC", PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
TraceTime t1(GCCauseString("GC", gch->gc_cause()), PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
||||||
// Capture heap used before collection (for printing).
|
// Capture heap used before collection (for printing).
|
||||||
size_t gch_prev_used = gch->used();
|
size_t gch_prev_used = gch->used();
|
||||||
|
|
||||||
|
@ -160,16 +160,10 @@ bool PSMarkSweep::invoke_no_policy(bool clear_all_softrefs) {
|
|||||||
|
|
||||||
{
|
{
|
||||||
HandleMark hm;
|
HandleMark hm;
|
||||||
const bool is_system_gc = gc_cause == GCCause::_java_lang_system_gc;
|
|
||||||
// This is useful for debugging but don't change the output the
|
|
||||||
// the customer sees.
|
|
||||||
const char* gc_cause_str = "Full GC";
|
|
||||||
if (is_system_gc && PrintGCDetails) {
|
|
||||||
gc_cause_str = "Full GC (System)";
|
|
||||||
}
|
|
||||||
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
||||||
TraceTime t1(gc_cause_str, PrintGC, !PrintGCDetails, gclog_or_tty);
|
TraceTime t1(GCCauseString("Full GC", gc_cause), PrintGC, !PrintGCDetails, gclog_or_tty);
|
||||||
TraceCollectorStats tcs(counters());
|
TraceCollectorStats tcs(counters());
|
||||||
TraceMemoryManagerStats tms(true /* Full GC */,gc_cause);
|
TraceMemoryManagerStats tms(true /* Full GC */,gc_cause);
|
||||||
|
|
||||||
|
@ -2047,17 +2047,9 @@ bool PSParallelCompact::invoke_no_policy(bool maximum_heap_compaction) {
|
|||||||
gc_task_manager()->task_idle_workers();
|
gc_task_manager()->task_idle_workers();
|
||||||
heap->set_par_threads(gc_task_manager()->active_workers());
|
heap->set_par_threads(gc_task_manager()->active_workers());
|
||||||
|
|
||||||
const bool is_system_gc = gc_cause == GCCause::_java_lang_system_gc;
|
|
||||||
|
|
||||||
// This is useful for debugging but don't change the output the
|
|
||||||
// the customer sees.
|
|
||||||
const char* gc_cause_str = "Full GC";
|
|
||||||
if (is_system_gc && PrintGCDetails) {
|
|
||||||
gc_cause_str = "Full GC (System)";
|
|
||||||
}
|
|
||||||
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
||||||
TraceTime t1(gc_cause_str, PrintGC, !PrintGCDetails, gclog_or_tty);
|
TraceTime t1(GCCauseString("Full GC", gc_cause), PrintGC, !PrintGCDetails, gclog_or_tty);
|
||||||
TraceCollectorStats tcs(counters());
|
TraceCollectorStats tcs(counters());
|
||||||
TraceMemoryManagerStats tms(true /* Full GC */,gc_cause);
|
TraceMemoryManagerStats tms(true /* Full GC */,gc_cause);
|
||||||
|
|
||||||
@ -2090,7 +2082,8 @@ bool PSParallelCompact::invoke_no_policy(bool maximum_heap_compaction) {
|
|||||||
}
|
}
|
||||||
#endif // #ifndef PRODUCT
|
#endif // #ifndef PRODUCT
|
||||||
|
|
||||||
bool max_on_system_gc = UseMaximumCompactionOnSystemGC && is_system_gc;
|
bool max_on_system_gc = UseMaximumCompactionOnSystemGC
|
||||||
|
&& gc_cause == GCCause::_java_lang_system_gc;
|
||||||
summary_phase(vmthread_cm, maximum_heap_compaction || max_on_system_gc);
|
summary_phase(vmthread_cm, maximum_heap_compaction || max_on_system_gc);
|
||||||
|
|
||||||
COMPILER2_PRESENT(assert(DerivedPointerTable::is_active(), "Sanity"));
|
COMPILER2_PRESENT(assert(DerivedPointerTable::is_active(), "Sanity"));
|
||||||
|
@ -325,7 +325,7 @@ bool PSScavenge::invoke_no_policy() {
|
|||||||
|
|
||||||
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
||||||
TraceTime t1("GC", PrintGC, !PrintGCDetails, gclog_or_tty);
|
TraceTime t1(GCCauseString("GC", gc_cause), PrintGC, !PrintGCDetails, gclog_or_tty);
|
||||||
TraceCollectorStats tcs(counters());
|
TraceCollectorStats tcs(counters());
|
||||||
TraceMemoryManagerStats tms(false /* not full GC */,gc_cause);
|
TraceMemoryManagerStats tms(false /* not full GC */,gc_cause);
|
||||||
|
|
||||||
|
@ -31,9 +31,15 @@ float AdaptiveWeightedAverage::compute_adaptive_average(float new_sample,
|
|||||||
float average) {
|
float average) {
|
||||||
// We smooth the samples by not using weight() directly until we've
|
// We smooth the samples by not using weight() directly until we've
|
||||||
// had enough data to make it meaningful. We'd like the first weight
|
// had enough data to make it meaningful. We'd like the first weight
|
||||||
// used to be 1, the second to be 1/2, etc until we have 100/weight
|
// used to be 1, the second to be 1/2, etc until we have
|
||||||
// samples.
|
// OLD_THRESHOLD/weight samples.
|
||||||
unsigned count_weight = 100/count();
|
unsigned count_weight = 0;
|
||||||
|
|
||||||
|
// Avoid division by zero if the counter wraps (7158457)
|
||||||
|
if (!is_old()) {
|
||||||
|
count_weight = OLD_THRESHOLD/count();
|
||||||
|
}
|
||||||
|
|
||||||
unsigned adaptive_weight = (MAX2(weight(), count_weight));
|
unsigned adaptive_weight = (MAX2(weight(), count_weight));
|
||||||
|
|
||||||
float new_avg = exp_avg(average, new_sample, adaptive_weight);
|
float new_avg = exp_avg(average, new_sample, adaptive_weight);
|
||||||
@ -43,8 +49,6 @@ float AdaptiveWeightedAverage::compute_adaptive_average(float new_sample,
|
|||||||
|
|
||||||
void AdaptiveWeightedAverage::sample(float new_sample) {
|
void AdaptiveWeightedAverage::sample(float new_sample) {
|
||||||
increment_count();
|
increment_count();
|
||||||
assert(count() != 0,
|
|
||||||
"Wraparound -- history would be incorrectly discarded");
|
|
||||||
|
|
||||||
// Compute the new weighted average
|
// Compute the new weighted average
|
||||||
float new_avg = compute_adaptive_average(new_sample, average());
|
float new_avg = compute_adaptive_average(new_sample, average());
|
||||||
|
@ -50,11 +50,20 @@ class AdaptiveWeightedAverage : public CHeapObj {
|
|||||||
unsigned _weight; // The weight used to smooth the averages
|
unsigned _weight; // The weight used to smooth the averages
|
||||||
// A higher weight favors the most
|
// A higher weight favors the most
|
||||||
// recent data.
|
// recent data.
|
||||||
|
bool _is_old; // Has enough historical data
|
||||||
|
|
||||||
|
const static unsigned OLD_THRESHOLD = 100;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
float _last_sample; // The last value sampled.
|
float _last_sample; // The last value sampled.
|
||||||
|
|
||||||
void increment_count() { _sample_count++; }
|
void increment_count() {
|
||||||
|
_sample_count++;
|
||||||
|
if (!_is_old && _sample_count > OLD_THRESHOLD) {
|
||||||
|
_is_old = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void set_average(float avg) { _average = avg; }
|
void set_average(float avg) { _average = avg; }
|
||||||
|
|
||||||
// Helper function, computes an adaptive weighted average
|
// Helper function, computes an adaptive weighted average
|
||||||
@ -64,13 +73,15 @@ class AdaptiveWeightedAverage : public CHeapObj {
|
|||||||
public:
|
public:
|
||||||
// Input weight must be between 0 and 100
|
// Input weight must be between 0 and 100
|
||||||
AdaptiveWeightedAverage(unsigned weight, float avg = 0.0) :
|
AdaptiveWeightedAverage(unsigned weight, float avg = 0.0) :
|
||||||
_average(avg), _sample_count(0), _weight(weight), _last_sample(0.0) {
|
_average(avg), _sample_count(0), _weight(weight), _last_sample(0.0),
|
||||||
|
_is_old(false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear() {
|
void clear() {
|
||||||
_average = 0;
|
_average = 0;
|
||||||
_sample_count = 0;
|
_sample_count = 0;
|
||||||
_last_sample = 0;
|
_last_sample = 0;
|
||||||
|
_is_old = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Useful for modifying static structures after startup.
|
// Useful for modifying static structures after startup.
|
||||||
@ -84,7 +95,8 @@ class AdaptiveWeightedAverage : public CHeapObj {
|
|||||||
float average() const { return _average; }
|
float average() const { return _average; }
|
||||||
unsigned weight() const { return _weight; }
|
unsigned weight() const { return _weight; }
|
||||||
unsigned count() const { return _sample_count; }
|
unsigned count() const { return _sample_count; }
|
||||||
float last_sample() const { return _last_sample; }
|
float last_sample() const { return _last_sample; }
|
||||||
|
bool is_old() const { return _is_old; }
|
||||||
|
|
||||||
// Update data with a new sample.
|
// Update data with a new sample.
|
||||||
void sample(float new_sample);
|
void sample(float new_sample);
|
||||||
|
@ -88,4 +88,36 @@ class GCCause : public AllStatic {
|
|||||||
static const char* to_string(GCCause::Cause cause);
|
static const char* to_string(GCCause::Cause cause);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Helper class for doing logging that includes the GC Cause
|
||||||
|
// as a string.
|
||||||
|
class GCCauseString : StackObj {
|
||||||
|
private:
|
||||||
|
static const int _length = 128;
|
||||||
|
char _buffer[_length];
|
||||||
|
int _position;
|
||||||
|
|
||||||
|
public:
|
||||||
|
GCCauseString(const char* prefix, GCCause::Cause cause) {
|
||||||
|
if (PrintGCCause) {
|
||||||
|
_position = jio_snprintf(_buffer, _length, "%s (%s)", prefix, GCCause::to_string(cause));
|
||||||
|
} else {
|
||||||
|
_position = jio_snprintf(_buffer, _length, "%s", prefix);
|
||||||
|
}
|
||||||
|
assert(_position >= 0 && _position <= _length,
|
||||||
|
err_msg("Need to increase the buffer size in GCCauseString? %d", _position));
|
||||||
|
}
|
||||||
|
|
||||||
|
GCCauseString& append(const char* str) {
|
||||||
|
int res = jio_snprintf(_buffer + _position, _length - _position, "%s", str);
|
||||||
|
_position += res;
|
||||||
|
assert(res >= 0 && _position <= _length,
|
||||||
|
err_msg("Need to increase the buffer size in GCCauseString? %d", res));
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
operator const char*() {
|
||||||
|
return _buffer;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
#endif // SHARE_VM_GC_INTERFACE_GCCAUSE_HPP
|
#endif // SHARE_VM_GC_INTERFACE_GCCAUSE_HPP
|
||||||
|
@ -548,7 +548,7 @@ void DefNewGeneration::collect(bool full,
|
|||||||
|
|
||||||
init_assuming_no_promotion_failure();
|
init_assuming_no_promotion_failure();
|
||||||
|
|
||||||
TraceTime t1("GC", PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
TraceTime t1(GCCauseString("GC", gch->gc_cause()), PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
||||||
// Capture heap used before collection (for printing).
|
// Capture heap used before collection (for printing).
|
||||||
size_t gch_prev_used = gch->used();
|
size_t gch_prev_used = gch->used();
|
||||||
|
|
||||||
|
@ -78,8 +78,8 @@ public:
|
|||||||
void do_oop(oop* p) {
|
void do_oop(oop* p) {
|
||||||
if (p != NULL) {
|
if (p != NULL) {
|
||||||
oop obj = *p;
|
oop obj = *p;
|
||||||
if (obj->klass() == SystemDictionary::String_klass()) {
|
if (obj->klass() == SystemDictionary::String_klass() &&
|
||||||
|
java_lang_String::has_hash_field()) {
|
||||||
int hash = java_lang_String::hash_string(obj);
|
int hash = java_lang_String::hash_string(obj);
|
||||||
obj->int_field_put(hash_offset, hash);
|
obj->int_field_put(hash_offset, hash);
|
||||||
}
|
}
|
||||||
|
@ -480,26 +480,15 @@ void GenCollectedHeap::do_collection(bool full,
|
|||||||
const size_t perm_prev_used = perm_gen()->used();
|
const size_t perm_prev_used = perm_gen()->used();
|
||||||
|
|
||||||
print_heap_before_gc();
|
print_heap_before_gc();
|
||||||
if (Verbose) {
|
|
||||||
gclog_or_tty->print_cr("GC Cause: %s", GCCause::to_string(gc_cause()));
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
FlagSetting fl(_is_gc_active, true);
|
FlagSetting fl(_is_gc_active, true);
|
||||||
|
|
||||||
bool complete = full && (max_level == (n_gens()-1));
|
bool complete = full && (max_level == (n_gens()-1));
|
||||||
const char* gc_cause_str = "GC ";
|
const char* gc_cause_prefix = complete ? "Full GC" : "GC";
|
||||||
if (complete) {
|
|
||||||
GCCause::Cause cause = gc_cause();
|
|
||||||
if (cause == GCCause::_java_lang_system_gc) {
|
|
||||||
gc_cause_str = "Full GC (System) ";
|
|
||||||
} else {
|
|
||||||
gc_cause_str = "Full GC ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
gclog_or_tty->date_stamp(PrintGC && PrintGCDateStamps);
|
||||||
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
TraceCPUTime tcpu(PrintGCDetails, true, gclog_or_tty);
|
||||||
TraceTime t(gc_cause_str, PrintGCDetails, false, gclog_or_tty);
|
TraceTime t(GCCauseString(gc_cause_prefix, gc_cause()), PrintGCDetails, false, gclog_or_tty);
|
||||||
|
|
||||||
gc_prologue(complete);
|
gc_prologue(complete);
|
||||||
increment_total_collections(complete);
|
increment_total_collections(complete);
|
||||||
|
@ -76,7 +76,7 @@ void GenMarkSweep::invoke_at_safepoint(int level, ReferenceProcessor* rp,
|
|||||||
_ref_processor = rp;
|
_ref_processor = rp;
|
||||||
rp->setup_policy(clear_all_softrefs);
|
rp->setup_policy(clear_all_softrefs);
|
||||||
|
|
||||||
TraceTime t1("Full GC", PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
TraceTime t1(GCCauseString("Full GC", gch->gc_cause()), PrintGC && !PrintGCDetails, true, gclog_or_tty);
|
||||||
|
|
||||||
// When collecting the permanent generation methodOops may be moving,
|
// When collecting the permanent generation methodOops may be moving,
|
||||||
// so we either have to flush all bcp data or convert it into bci.
|
// so we either have to flush all bcp data or convert it into bci.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -3748,3 +3748,81 @@ void GraphKit::g1_write_barrier_post(Node* oop_store,
|
|||||||
final_sync(ideal);
|
final_sync(ideal);
|
||||||
}
|
}
|
||||||
#undef __
|
#undef __
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Node* GraphKit::load_String_offset(Node* ctrl, Node* str) {
|
||||||
|
if (java_lang_String::has_offset_field()) {
|
||||||
|
int offset_offset = java_lang_String::offset_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* offset_field_type = string_type->add_offset(offset_offset);
|
||||||
|
int offset_field_idx = C->get_alias_index(offset_field_type);
|
||||||
|
return make_load(ctrl,
|
||||||
|
basic_plus_adr(str, str, offset_offset),
|
||||||
|
TypeInt::INT, T_INT, offset_field_idx);
|
||||||
|
} else {
|
||||||
|
return intcon(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Node* GraphKit::load_String_length(Node* ctrl, Node* str) {
|
||||||
|
if (java_lang_String::has_count_field()) {
|
||||||
|
int count_offset = java_lang_String::count_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* count_field_type = string_type->add_offset(count_offset);
|
||||||
|
int count_field_idx = C->get_alias_index(count_field_type);
|
||||||
|
return make_load(ctrl,
|
||||||
|
basic_plus_adr(str, str, count_offset),
|
||||||
|
TypeInt::INT, T_INT, count_field_idx);
|
||||||
|
} else {
|
||||||
|
return load_array_length(load_String_value(ctrl, str));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Node* GraphKit::load_String_value(Node* ctrl, Node* str) {
|
||||||
|
int value_offset = java_lang_String::value_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* value_field_type = string_type->add_offset(value_offset);
|
||||||
|
const TypeAryPtr* value_type = TypeAryPtr::make(TypePtr::NotNull,
|
||||||
|
TypeAry::make(TypeInt::CHAR,TypeInt::POS),
|
||||||
|
ciTypeArrayKlass::make(T_CHAR), true, 0);
|
||||||
|
int value_field_idx = C->get_alias_index(value_field_type);
|
||||||
|
return make_load(ctrl, basic_plus_adr(str, str, value_offset),
|
||||||
|
value_type, T_OBJECT, value_field_idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GraphKit::store_String_offset(Node* ctrl, Node* str, Node* value) {
|
||||||
|
int offset_offset = java_lang_String::offset_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* offset_field_type = string_type->add_offset(offset_offset);
|
||||||
|
int offset_field_idx = C->get_alias_index(offset_field_type);
|
||||||
|
store_to_memory(ctrl, basic_plus_adr(str, offset_offset),
|
||||||
|
value, T_INT, offset_field_idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GraphKit::store_String_value(Node* ctrl, Node* str, Node* value) {
|
||||||
|
int value_offset = java_lang_String::value_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* value_field_type = string_type->add_offset(value_offset);
|
||||||
|
const TypeAryPtr* value_type = TypeAryPtr::make(TypePtr::NotNull,
|
||||||
|
TypeAry::make(TypeInt::CHAR,TypeInt::POS),
|
||||||
|
ciTypeArrayKlass::make(T_CHAR), true, 0);
|
||||||
|
int value_field_idx = C->get_alias_index(value_field_type);
|
||||||
|
store_to_memory(ctrl, basic_plus_adr(str, value_offset),
|
||||||
|
value, T_OBJECT, value_field_idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GraphKit::store_String_length(Node* ctrl, Node* str, Node* value) {
|
||||||
|
int count_offset = java_lang_String::count_offset_in_bytes();
|
||||||
|
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
||||||
|
false, NULL, 0);
|
||||||
|
const TypePtr* count_field_type = string_type->add_offset(count_offset);
|
||||||
|
int count_field_idx = C->get_alias_index(count_field_type);
|
||||||
|
store_to_memory(ctrl, basic_plus_adr(str, count_offset),
|
||||||
|
value, T_INT, count_field_idx);
|
||||||
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -781,6 +781,14 @@ class GraphKit : public Phase {
|
|||||||
Node* new_array(Node* klass_node, Node* count_val, int nargs,
|
Node* new_array(Node* klass_node, Node* count_val, int nargs,
|
||||||
Node* *return_size_val = NULL);
|
Node* *return_size_val = NULL);
|
||||||
|
|
||||||
|
// java.lang.String helpers
|
||||||
|
Node* load_String_offset(Node* ctrl, Node* str);
|
||||||
|
Node* load_String_length(Node* ctrl, Node* str);
|
||||||
|
Node* load_String_value(Node* ctrl, Node* str);
|
||||||
|
void store_String_offset(Node* ctrl, Node* str, Node* value);
|
||||||
|
void store_String_length(Node* ctrl, Node* str, Node* value);
|
||||||
|
void store_String_value(Node* ctrl, Node* str, Node* value);
|
||||||
|
|
||||||
// Handy for making control flow
|
// Handy for making control flow
|
||||||
IfNode* create_and_map_if(Node* ctrl, Node* tst, float prob, float cnt) {
|
IfNode* create_and_map_if(Node* ctrl, Node* tst, float prob, float cnt) {
|
||||||
IfNode* iff = new (C, 2) IfNode(ctrl, tst, prob, cnt);// New IfNode's
|
IfNode* iff = new (C, 2) IfNode(ctrl, tst, prob, cnt);// New IfNode's
|
||||||
|
@ -147,7 +147,8 @@ class LibraryCallKit : public GraphKit {
|
|||||||
return generate_method_call(method_id, true, false);
|
return generate_method_call(method_id, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
Node* make_string_method_node(int opcode, Node* str1, Node* cnt1, Node* str2, Node* cnt2);
|
Node* make_string_method_node(int opcode, Node* str1_start, Node* cnt1, Node* str2_start, Node* cnt2);
|
||||||
|
Node* make_string_method_node(int opcode, Node* str1, Node* str2);
|
||||||
bool inline_string_compareTo();
|
bool inline_string_compareTo();
|
||||||
bool inline_string_indexOf();
|
bool inline_string_indexOf();
|
||||||
Node* string_indexOf(Node* string_object, ciTypeArray* target_array, jint offset, jint cache_i, jint md2_i);
|
Node* string_indexOf(Node* string_object, ciTypeArray* target_array, jint offset, jint cache_i, jint md2_i);
|
||||||
@ -873,48 +874,76 @@ Node* LibraryCallKit::generate_current_thread(Node* &tls_output) {
|
|||||||
|
|
||||||
|
|
||||||
//------------------------------make_string_method_node------------------------
|
//------------------------------make_string_method_node------------------------
|
||||||
// Helper method for String intrinsic finctions.
|
// Helper method for String intrinsic functions. This version is called
|
||||||
Node* LibraryCallKit::make_string_method_node(int opcode, Node* str1, Node* cnt1, Node* str2, Node* cnt2) {
|
// with str1 and str2 pointing to String object nodes.
|
||||||
const int value_offset = java_lang_String::value_offset_in_bytes();
|
//
|
||||||
const int count_offset = java_lang_String::count_offset_in_bytes();
|
Node* LibraryCallKit::make_string_method_node(int opcode, Node* str1, Node* str2) {
|
||||||
const int offset_offset = java_lang_String::offset_offset_in_bytes();
|
|
||||||
|
|
||||||
Node* no_ctrl = NULL;
|
Node* no_ctrl = NULL;
|
||||||
|
|
||||||
ciInstanceKlass* klass = env()->String_klass();
|
// Get start addr of string
|
||||||
const TypeOopPtr* string_type = TypeOopPtr::make_from_klass(klass);
|
Node* str1_value = load_String_value(no_ctrl, str1);
|
||||||
|
Node* str1_offset = load_String_offset(no_ctrl, str1);
|
||||||
const TypeAryPtr* value_type =
|
|
||||||
TypeAryPtr::make(TypePtr::NotNull,
|
|
||||||
TypeAry::make(TypeInt::CHAR,TypeInt::POS),
|
|
||||||
ciTypeArrayKlass::make(T_CHAR), true, 0);
|
|
||||||
|
|
||||||
// Get start addr of string and substring
|
|
||||||
Node* str1_valuea = basic_plus_adr(str1, str1, value_offset);
|
|
||||||
Node* str1_value = make_load(no_ctrl, str1_valuea, value_type, T_OBJECT, string_type->add_offset(value_offset));
|
|
||||||
Node* str1_offseta = basic_plus_adr(str1, str1, offset_offset);
|
|
||||||
Node* str1_offset = make_load(no_ctrl, str1_offseta, TypeInt::INT, T_INT, string_type->add_offset(offset_offset));
|
|
||||||
Node* str1_start = array_element_address(str1_value, str1_offset, T_CHAR);
|
Node* str1_start = array_element_address(str1_value, str1_offset, T_CHAR);
|
||||||
|
|
||||||
Node* str2_valuea = basic_plus_adr(str2, str2, value_offset);
|
// Get length of string 1
|
||||||
Node* str2_value = make_load(no_ctrl, str2_valuea, value_type, T_OBJECT, string_type->add_offset(value_offset));
|
Node* str1_len = load_String_length(no_ctrl, str1);
|
||||||
Node* str2_offseta = basic_plus_adr(str2, str2, offset_offset);
|
|
||||||
Node* str2_offset = make_load(no_ctrl, str2_offseta, TypeInt::INT, T_INT, string_type->add_offset(offset_offset));
|
Node* str2_value = load_String_value(no_ctrl, str2);
|
||||||
|
Node* str2_offset = load_String_offset(no_ctrl, str2);
|
||||||
Node* str2_start = array_element_address(str2_value, str2_offset, T_CHAR);
|
Node* str2_start = array_element_address(str2_value, str2_offset, T_CHAR);
|
||||||
|
|
||||||
|
Node* str2_len = NULL;
|
||||||
|
Node* result = NULL;
|
||||||
|
|
||||||
|
switch (opcode) {
|
||||||
|
case Op_StrIndexOf:
|
||||||
|
// Get length of string 2
|
||||||
|
str2_len = load_String_length(no_ctrl, str2);
|
||||||
|
|
||||||
|
result = new (C, 6) StrIndexOfNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
|
str1_start, str1_len, str2_start, str2_len);
|
||||||
|
break;
|
||||||
|
case Op_StrComp:
|
||||||
|
// Get length of string 2
|
||||||
|
str2_len = load_String_length(no_ctrl, str2);
|
||||||
|
|
||||||
|
result = new (C, 6) StrCompNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
|
str1_start, str1_len, str2_start, str2_len);
|
||||||
|
break;
|
||||||
|
case Op_StrEquals:
|
||||||
|
result = new (C, 5) StrEqualsNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
|
str1_start, str2_start, str1_len);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ShouldNotReachHere();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// All these intrinsics have checks.
|
||||||
|
C->set_has_split_ifs(true); // Has chance for split-if optimization
|
||||||
|
|
||||||
|
return _gvn.transform(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper method for String intrinsic functions. This version is called
|
||||||
|
// with str1 and str2 pointing to char[] nodes, with cnt1 and cnt2 pointing
|
||||||
|
// to Int nodes containing the lenghts of str1 and str2.
|
||||||
|
//
|
||||||
|
Node* LibraryCallKit::make_string_method_node(int opcode, Node* str1_start, Node* cnt1, Node* str2_start, Node* cnt2) {
|
||||||
|
|
||||||
Node* result = NULL;
|
Node* result = NULL;
|
||||||
switch (opcode) {
|
switch (opcode) {
|
||||||
case Op_StrIndexOf:
|
case Op_StrIndexOf:
|
||||||
result = new (C, 6) StrIndexOfNode(control(), memory(TypeAryPtr::CHARS),
|
result = new (C, 6) StrIndexOfNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
str1_start, cnt1, str2_start, cnt2);
|
str1_start, cnt1, str2_start, cnt2);
|
||||||
break;
|
break;
|
||||||
case Op_StrComp:
|
case Op_StrComp:
|
||||||
result = new (C, 6) StrCompNode(control(), memory(TypeAryPtr::CHARS),
|
result = new (C, 6) StrCompNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
str1_start, cnt1, str2_start, cnt2);
|
str1_start, cnt1, str2_start, cnt2);
|
||||||
break;
|
break;
|
||||||
case Op_StrEquals:
|
case Op_StrEquals:
|
||||||
result = new (C, 5) StrEqualsNode(control(), memory(TypeAryPtr::CHARS),
|
result = new (C, 5) StrEqualsNode(control(), memory(TypeAryPtr::CHARS),
|
||||||
str1_start, str2_start, cnt1);
|
str1_start, str2_start, cnt1);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
@ -932,10 +961,6 @@ bool LibraryCallKit::inline_string_compareTo() {
|
|||||||
|
|
||||||
if (!Matcher::has_match_rule(Op_StrComp)) return false;
|
if (!Matcher::has_match_rule(Op_StrComp)) return false;
|
||||||
|
|
||||||
const int value_offset = java_lang_String::value_offset_in_bytes();
|
|
||||||
const int count_offset = java_lang_String::count_offset_in_bytes();
|
|
||||||
const int offset_offset = java_lang_String::offset_offset_in_bytes();
|
|
||||||
|
|
||||||
_sp += 2;
|
_sp += 2;
|
||||||
Node *argument = pop(); // pop non-receiver first: it was pushed second
|
Node *argument = pop(); // pop non-receiver first: it was pushed second
|
||||||
Node *receiver = pop();
|
Node *receiver = pop();
|
||||||
@ -952,18 +977,7 @@ bool LibraryCallKit::inline_string_compareTo() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciInstanceKlass* klass = env()->String_klass();
|
Node* compare = make_string_method_node(Op_StrComp, receiver, argument);
|
||||||
const TypeOopPtr* string_type = TypeOopPtr::make_from_klass(klass);
|
|
||||||
Node* no_ctrl = NULL;
|
|
||||||
|
|
||||||
// Get counts for string and argument
|
|
||||||
Node* receiver_cnta = basic_plus_adr(receiver, receiver, count_offset);
|
|
||||||
Node* receiver_cnt = make_load(no_ctrl, receiver_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
|
||||||
|
|
||||||
Node* argument_cnta = basic_plus_adr(argument, argument, count_offset);
|
|
||||||
Node* argument_cnt = make_load(no_ctrl, argument_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
|
||||||
|
|
||||||
Node* compare = make_string_method_node(Op_StrComp, receiver, receiver_cnt, argument, argument_cnt);
|
|
||||||
push(compare);
|
push(compare);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -973,10 +987,6 @@ bool LibraryCallKit::inline_string_equals() {
|
|||||||
|
|
||||||
if (!Matcher::has_match_rule(Op_StrEquals)) return false;
|
if (!Matcher::has_match_rule(Op_StrEquals)) return false;
|
||||||
|
|
||||||
const int value_offset = java_lang_String::value_offset_in_bytes();
|
|
||||||
const int count_offset = java_lang_String::count_offset_in_bytes();
|
|
||||||
const int offset_offset = java_lang_String::offset_offset_in_bytes();
|
|
||||||
|
|
||||||
int nargs = 2;
|
int nargs = 2;
|
||||||
_sp += nargs;
|
_sp += nargs;
|
||||||
Node* argument = pop(); // pop non-receiver first: it was pushed second
|
Node* argument = pop(); // pop non-receiver first: it was pushed second
|
||||||
@ -1030,24 +1040,31 @@ bool LibraryCallKit::inline_string_equals() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const TypeOopPtr* string_type = TypeOopPtr::make_from_klass(klass);
|
|
||||||
|
|
||||||
Node* no_ctrl = NULL;
|
|
||||||
Node* receiver_cnt;
|
|
||||||
Node* argument_cnt;
|
|
||||||
|
|
||||||
if (!stopped()) {
|
if (!stopped()) {
|
||||||
|
const TypeOopPtr* string_type = TypeOopPtr::make_from_klass(klass);
|
||||||
|
|
||||||
// Properly cast the argument to String
|
// Properly cast the argument to String
|
||||||
argument = _gvn.transform(new (C, 2) CheckCastPPNode(control(), argument, string_type));
|
argument = _gvn.transform(new (C, 2) CheckCastPPNode(control(), argument, string_type));
|
||||||
// This path is taken only when argument's type is String:NotNull.
|
// This path is taken only when argument's type is String:NotNull.
|
||||||
argument = cast_not_null(argument, false);
|
argument = cast_not_null(argument, false);
|
||||||
|
|
||||||
// Get counts for string and argument
|
Node* no_ctrl = NULL;
|
||||||
Node* receiver_cnta = basic_plus_adr(receiver, receiver, count_offset);
|
|
||||||
receiver_cnt = make_load(no_ctrl, receiver_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
|
||||||
|
|
||||||
Node* argument_cnta = basic_plus_adr(argument, argument, count_offset);
|
// Get start addr of receiver
|
||||||
argument_cnt = make_load(no_ctrl, argument_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
Node* receiver_val = load_String_value(no_ctrl, receiver);
|
||||||
|
Node* receiver_offset = load_String_offset(no_ctrl, receiver);
|
||||||
|
Node* receiver_start = array_element_address(receiver_val, receiver_offset, T_CHAR);
|
||||||
|
|
||||||
|
// Get length of receiver
|
||||||
|
Node* receiver_cnt = load_String_length(no_ctrl, receiver);
|
||||||
|
|
||||||
|
// Get start addr of argument
|
||||||
|
Node* argument_val = load_String_value(no_ctrl, argument);
|
||||||
|
Node* argument_offset = load_String_offset(no_ctrl, argument);
|
||||||
|
Node* argument_start = array_element_address(argument_val, argument_offset, T_CHAR);
|
||||||
|
|
||||||
|
// Get length of argument
|
||||||
|
Node* argument_cnt = load_String_length(no_ctrl, argument);
|
||||||
|
|
||||||
// Check for receiver count != argument count
|
// Check for receiver count != argument count
|
||||||
Node* cmp = _gvn.transform( new(C, 3) CmpINode(receiver_cnt, argument_cnt) );
|
Node* cmp = _gvn.transform( new(C, 3) CmpINode(receiver_cnt, argument_cnt) );
|
||||||
@ -1057,14 +1074,14 @@ bool LibraryCallKit::inline_string_equals() {
|
|||||||
phi->init_req(4, intcon(0));
|
phi->init_req(4, intcon(0));
|
||||||
region->init_req(4, if_ne);
|
region->init_req(4, if_ne);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Check for count == 0 is done by mach node StrEquals.
|
// Check for count == 0 is done by assembler code for StrEquals.
|
||||||
|
|
||||||
if (!stopped()) {
|
if (!stopped()) {
|
||||||
Node* equals = make_string_method_node(Op_StrEquals, receiver, receiver_cnt, argument, argument_cnt);
|
Node* equals = make_string_method_node(Op_StrEquals, receiver_start, receiver_cnt, argument_start, argument_cnt);
|
||||||
phi->init_req(1, equals);
|
phi->init_req(1, equals);
|
||||||
region->init_req(1, control());
|
region->init_req(1, control());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// post merge
|
// post merge
|
||||||
@ -1162,20 +1179,9 @@ Node* LibraryCallKit::string_indexOf(Node* string_object, ciTypeArray* target_ar
|
|||||||
|
|
||||||
const int nargs = 2; // number of arguments to push back for uncommon trap in predicate
|
const int nargs = 2; // number of arguments to push back for uncommon trap in predicate
|
||||||
|
|
||||||
const int value_offset = java_lang_String::value_offset_in_bytes();
|
Node* source = load_String_value(no_ctrl, string_object);
|
||||||
const int count_offset = java_lang_String::count_offset_in_bytes();
|
Node* sourceOffset = load_String_offset(no_ctrl, string_object);
|
||||||
const int offset_offset = java_lang_String::offset_offset_in_bytes();
|
Node* sourceCount = load_String_length(no_ctrl, string_object);
|
||||||
|
|
||||||
ciInstanceKlass* klass = env()->String_klass();
|
|
||||||
const TypeOopPtr* string_type = TypeOopPtr::make_from_klass(klass);
|
|
||||||
const TypeAryPtr* source_type = TypeAryPtr::make(TypePtr::NotNull, TypeAry::make(TypeInt::CHAR,TypeInt::POS), ciTypeArrayKlass::make(T_CHAR), true, 0);
|
|
||||||
|
|
||||||
Node* sourceOffseta = basic_plus_adr(string_object, string_object, offset_offset);
|
|
||||||
Node* sourceOffset = make_load(no_ctrl, sourceOffseta, TypeInt::INT, T_INT, string_type->add_offset(offset_offset));
|
|
||||||
Node* sourceCounta = basic_plus_adr(string_object, string_object, count_offset);
|
|
||||||
Node* sourceCount = make_load(no_ctrl, sourceCounta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
|
||||||
Node* sourcea = basic_plus_adr(string_object, string_object, value_offset);
|
|
||||||
Node* source = make_load(no_ctrl, sourcea, source_type, T_OBJECT, string_type->add_offset(value_offset));
|
|
||||||
|
|
||||||
Node* target = _gvn.transform( makecon(TypeOopPtr::make_from_constant(target_array, true)) );
|
Node* target = _gvn.transform( makecon(TypeOopPtr::make_from_constant(target_array, true)) );
|
||||||
jint target_length = target_array->length();
|
jint target_length = target_array->length();
|
||||||
@ -1243,10 +1249,6 @@ Node* LibraryCallKit::string_indexOf(Node* string_object, ciTypeArray* target_ar
|
|||||||
//------------------------------inline_string_indexOf------------------------
|
//------------------------------inline_string_indexOf------------------------
|
||||||
bool LibraryCallKit::inline_string_indexOf() {
|
bool LibraryCallKit::inline_string_indexOf() {
|
||||||
|
|
||||||
const int value_offset = java_lang_String::value_offset_in_bytes();
|
|
||||||
const int count_offset = java_lang_String::count_offset_in_bytes();
|
|
||||||
const int offset_offset = java_lang_String::offset_offset_in_bytes();
|
|
||||||
|
|
||||||
_sp += 2;
|
_sp += 2;
|
||||||
Node *argument = pop(); // pop non-receiver first: it was pushed second
|
Node *argument = pop(); // pop non-receiver first: it was pushed second
|
||||||
Node *receiver = pop();
|
Node *receiver = pop();
|
||||||
@ -1280,12 +1282,21 @@ bool LibraryCallKit::inline_string_indexOf() {
|
|||||||
Node* result_phi = new (C, 4) PhiNode(result_rgn, TypeInt::INT);
|
Node* result_phi = new (C, 4) PhiNode(result_rgn, TypeInt::INT);
|
||||||
Node* no_ctrl = NULL;
|
Node* no_ctrl = NULL;
|
||||||
|
|
||||||
// Get counts for string and substr
|
// Get start addr of source string
|
||||||
Node* source_cnta = basic_plus_adr(receiver, receiver, count_offset);
|
Node* source = load_String_value(no_ctrl, receiver);
|
||||||
Node* source_cnt = make_load(no_ctrl, source_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
Node* source_offset = load_String_offset(no_ctrl, receiver);
|
||||||
|
Node* source_start = array_element_address(source, source_offset, T_CHAR);
|
||||||
|
|
||||||
Node* substr_cnta = basic_plus_adr(argument, argument, count_offset);
|
// Get length of source string
|
||||||
Node* substr_cnt = make_load(no_ctrl, substr_cnta, TypeInt::INT, T_INT, string_type->add_offset(count_offset));
|
Node* source_cnt = load_String_length(no_ctrl, receiver);
|
||||||
|
|
||||||
|
// Get start addr of substring
|
||||||
|
Node* substr = load_String_value(no_ctrl, argument);
|
||||||
|
Node* substr_offset = load_String_offset(no_ctrl, argument);
|
||||||
|
Node* substr_start = array_element_address(substr, substr_offset, T_CHAR);
|
||||||
|
|
||||||
|
// Get length of source string
|
||||||
|
Node* substr_cnt = load_String_length(no_ctrl, argument);
|
||||||
|
|
||||||
// Check for substr count > string count
|
// Check for substr count > string count
|
||||||
Node* cmp = _gvn.transform( new(C, 3) CmpINode(substr_cnt, source_cnt) );
|
Node* cmp = _gvn.transform( new(C, 3) CmpINode(substr_cnt, source_cnt) );
|
||||||
@ -1308,7 +1319,7 @@ bool LibraryCallKit::inline_string_indexOf() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!stopped()) {
|
if (!stopped()) {
|
||||||
result = make_string_method_node(Op_StrIndexOf, receiver, source_cnt, argument, substr_cnt);
|
result = make_string_method_node(Op_StrIndexOf, source_start, source_cnt, substr_start, substr_cnt);
|
||||||
result_phi->init_req(1, result);
|
result_phi->init_req(1, result);
|
||||||
result_rgn->init_req(1, control());
|
result_rgn->init_req(1, control());
|
||||||
}
|
}
|
||||||
@ -1333,11 +1344,19 @@ bool LibraryCallKit::inline_string_indexOf() {
|
|||||||
ciInstance* str = str_const->as_instance();
|
ciInstance* str = str_const->as_instance();
|
||||||
assert(str != NULL, "must be instance");
|
assert(str != NULL, "must be instance");
|
||||||
|
|
||||||
ciObject* v = str->field_value_by_offset(value_offset).as_object();
|
ciObject* v = str->field_value_by_offset(java_lang_String::value_offset_in_bytes()).as_object();
|
||||||
int o = str->field_value_by_offset(offset_offset).as_int();
|
|
||||||
int c = str->field_value_by_offset(count_offset).as_int();
|
|
||||||
ciTypeArray* pat = v->as_type_array(); // pattern (argument) character array
|
ciTypeArray* pat = v->as_type_array(); // pattern (argument) character array
|
||||||
|
|
||||||
|
int o;
|
||||||
|
int c;
|
||||||
|
if (java_lang_String::has_offset_field()) {
|
||||||
|
o = str->field_value_by_offset(java_lang_String::offset_offset_in_bytes()).as_int();
|
||||||
|
c = str->field_value_by_offset(java_lang_String::count_offset_in_bytes()).as_int();
|
||||||
|
} else {
|
||||||
|
o = 0;
|
||||||
|
c = pat->length();
|
||||||
|
}
|
||||||
|
|
||||||
// constant strings have no offset and count == length which
|
// constant strings have no offset and count == length which
|
||||||
// simplifies the resulting code somewhat so lets optimize for that.
|
// simplifies the resulting code somewhat so lets optimize for that.
|
||||||
if (o != 0 || c != pat->length()) {
|
if (o != 0 || c != pat->length()) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -528,16 +528,6 @@ PhaseStringOpts::PhaseStringOpts(PhaseGVN* gvn, Unique_Node_List*):
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Collect the types needed to talk about the various slices of memory
|
// Collect the types needed to talk about the various slices of memory
|
||||||
const TypeInstPtr* string_type = TypeInstPtr::make(TypePtr::NotNull, C->env()->String_klass(),
|
|
||||||
false, NULL, 0);
|
|
||||||
|
|
||||||
const TypePtr* value_field_type = string_type->add_offset(java_lang_String::value_offset_in_bytes());
|
|
||||||
const TypePtr* offset_field_type = string_type->add_offset(java_lang_String::offset_offset_in_bytes());
|
|
||||||
const TypePtr* count_field_type = string_type->add_offset(java_lang_String::count_offset_in_bytes());
|
|
||||||
|
|
||||||
value_field_idx = C->get_alias_index(value_field_type);
|
|
||||||
count_field_idx = C->get_alias_index(count_field_type);
|
|
||||||
offset_field_idx = C->get_alias_index(offset_field_type);
|
|
||||||
char_adr_idx = C->get_alias_index(TypeAryPtr::CHARS);
|
char_adr_idx = C->get_alias_index(TypeAryPtr::CHARS);
|
||||||
|
|
||||||
// For each locally allocated StringBuffer see if the usages can be
|
// For each locally allocated StringBuffer see if the usages can be
|
||||||
@ -1174,18 +1164,9 @@ void PhaseStringOpts::int_getChars(GraphKit& kit, Node* arg, Node* char_array, N
|
|||||||
|
|
||||||
Node* PhaseStringOpts::copy_string(GraphKit& kit, Node* str, Node* char_array, Node* start) {
|
Node* PhaseStringOpts::copy_string(GraphKit& kit, Node* str, Node* char_array, Node* start) {
|
||||||
Node* string = str;
|
Node* string = str;
|
||||||
Node* offset = kit.make_load(kit.control(),
|
Node* offset = kit.load_String_offset(kit.control(), string);
|
||||||
kit.basic_plus_adr(string, string, java_lang_String::offset_offset_in_bytes()),
|
Node* count = kit.load_String_length(kit.control(), string);
|
||||||
TypeInt::INT, T_INT, offset_field_idx);
|
Node* value = kit.load_String_value (kit.control(), string);
|
||||||
Node* count = kit.make_load(kit.control(),
|
|
||||||
kit.basic_plus_adr(string, string, java_lang_String::count_offset_in_bytes()),
|
|
||||||
TypeInt::INT, T_INT, count_field_idx);
|
|
||||||
const TypeAryPtr* value_type = TypeAryPtr::make(TypePtr::NotNull,
|
|
||||||
TypeAry::make(TypeInt::CHAR,TypeInt::POS),
|
|
||||||
ciTypeArrayKlass::make(T_CHAR), true, 0);
|
|
||||||
Node* value = kit.make_load(kit.control(),
|
|
||||||
kit.basic_plus_adr(string, string, java_lang_String::value_offset_in_bytes()),
|
|
||||||
value_type, T_OBJECT, value_field_idx);
|
|
||||||
|
|
||||||
// copy the contents
|
// copy the contents
|
||||||
if (offset->is_Con() && count->is_Con() && value->is_Con() && count->get_int() < unroll_string_copy_length) {
|
if (offset->is_Con() && count->is_Con() && value->is_Con() && count->get_int() < unroll_string_copy_length) {
|
||||||
@ -1342,10 +1323,9 @@ void PhaseStringOpts::replace_string_concat(StringConcat* sc) {
|
|||||||
arg = phi;
|
arg = phi;
|
||||||
sc->set_argument(argi, arg);
|
sc->set_argument(argi, arg);
|
||||||
}
|
}
|
||||||
// Node* offset = kit.make_load(NULL, kit.basic_plus_adr(arg, arg, offset_offset),
|
|
||||||
// TypeInt::INT, T_INT, offset_field_idx);
|
Node* count = kit.load_String_length(kit.control(), arg);
|
||||||
Node* count = kit.make_load(kit.control(), kit.basic_plus_adr(arg, arg, java_lang_String::count_offset_in_bytes()),
|
|
||||||
TypeInt::INT, T_INT, count_field_idx);
|
|
||||||
length = __ AddI(length, count);
|
length = __ AddI(length, count);
|
||||||
string_sizes->init_req(argi, NULL);
|
string_sizes->init_req(argi, NULL);
|
||||||
break;
|
break;
|
||||||
@ -1436,12 +1416,11 @@ void PhaseStringOpts::replace_string_concat(StringConcat* sc) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Intialize the string
|
// Intialize the string
|
||||||
kit.store_to_memory(kit.control(), kit.basic_plus_adr(result, java_lang_String::offset_offset_in_bytes()),
|
if (java_lang_String::has_offset_field()) {
|
||||||
__ intcon(0), T_INT, offset_field_idx);
|
kit.store_String_offset(kit.control(), result, __ intcon(0));
|
||||||
kit.store_to_memory(kit.control(), kit.basic_plus_adr(result, java_lang_String::count_offset_in_bytes()),
|
kit.store_String_length(kit.control(), result, length);
|
||||||
length, T_INT, count_field_idx);
|
}
|
||||||
kit.store_to_memory(kit.control(), kit.basic_plus_adr(result, java_lang_String::value_offset_in_bytes()),
|
kit.store_String_value(kit.control(), result, char_array);
|
||||||
char_array, T_OBJECT, value_field_idx);
|
|
||||||
|
|
||||||
// hook up the outgoing control and result
|
// hook up the outgoing control and result
|
||||||
kit.replace_call(sc->end(), result);
|
kit.replace_call(sc->end(), result);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2009, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,9 +41,6 @@ class PhaseStringOpts : public Phase {
|
|||||||
|
|
||||||
// Memory slices needed for code gen
|
// Memory slices needed for code gen
|
||||||
int char_adr_idx;
|
int char_adr_idx;
|
||||||
int value_field_idx;
|
|
||||||
int count_field_idx;
|
|
||||||
int offset_field_idx;
|
|
||||||
|
|
||||||
// Integer.sizeTable - used for int to String conversion
|
// Integer.sizeTable - used for int to String conversion
|
||||||
ciField* size_table_field;
|
ciField* size_table_field;
|
||||||
|
@ -3039,7 +3039,7 @@ jint Arguments::parse(const JavaVMInitArgs* args) {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef JAVASE_EMBEDDED
|
#if (defined JAVASE_EMBEDDED || defined ARM)
|
||||||
UNSUPPORTED_OPTION(UseG1GC, "G1 GC");
|
UNSUPPORTED_OPTION(UseG1GC, "G1 GC");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -3092,6 +3092,14 @@ jint Arguments::parse(const JavaVMInitArgs* args) {
|
|||||||
PrintGC = true;
|
PrintGC = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!JDK_Version::is_gte_jdk18x_version()) {
|
||||||
|
// To avoid changing the log format for 7 updates this flag is only
|
||||||
|
// true by default in JDK8 and above.
|
||||||
|
if (FLAG_IS_DEFAULT(PrintGCCause)) {
|
||||||
|
FLAG_SET_DEFAULT(PrintGCCause, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Set object alignment values.
|
// Set object alignment values.
|
||||||
set_object_alignment();
|
set_object_alignment();
|
||||||
|
|
||||||
|
@ -3902,7 +3902,10 @@ class CommandLineFlags {
|
|||||||
" of this flag is true for JDK 6 and earlier") \
|
" of this flag is true for JDK 6 and earlier") \
|
||||||
\
|
\
|
||||||
diagnostic(bool, WhiteBoxAPI, false, \
|
diagnostic(bool, WhiteBoxAPI, false, \
|
||||||
"Enable internal testing APIs")
|
"Enable internal testing APIs") \
|
||||||
|
\
|
||||||
|
product(bool, PrintGCCause, true, \
|
||||||
|
"Include GC cause in GC logging")
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Macros for factoring of globals
|
* Macros for factoring of globals
|
||||||
|
@ -206,6 +206,10 @@ class JDK_Version VALUE_OBJ_CLASS_SPEC {
|
|||||||
return current().compare_major(7) == 0;
|
return current().compare_major(7) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool is_jdk18x_version() {
|
||||||
|
return current().compare_major(8) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
static bool is_gte_jdk13x_version() {
|
static bool is_gte_jdk13x_version() {
|
||||||
return current().compare_major(3) >= 0;
|
return current().compare_major(3) >= 0;
|
||||||
}
|
}
|
||||||
@ -225,6 +229,10 @@ class JDK_Version VALUE_OBJ_CLASS_SPEC {
|
|||||||
static bool is_gte_jdk17x_version() {
|
static bool is_gte_jdk17x_version() {
|
||||||
return current().compare_major(7) >= 0;
|
return current().compare_major(7) >= 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool is_gte_jdk18x_version() {
|
||||||
|
return current().compare_major(8) >= 0;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SHARE_VM_RUNTIME_JAVA_HPP
|
#endif // SHARE_VM_RUNTIME_JAVA_HPP
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -179,6 +179,11 @@ const jlong NANOSECS_PER_SEC = CONST64(1000000000);
|
|||||||
const jint NANOSECS_PER_MILLISEC = 1000000;
|
const jint NANOSECS_PER_MILLISEC = 1000000;
|
||||||
|
|
||||||
inline const char* proper_unit_for_byte_size(size_t s) {
|
inline const char* proper_unit_for_byte_size(size_t s) {
|
||||||
|
#ifdef _LP64
|
||||||
|
if (s >= 10*G) {
|
||||||
|
return "G";
|
||||||
|
}
|
||||||
|
#endif
|
||||||
if (s >= 10*M) {
|
if (s >= 10*M) {
|
||||||
return "M";
|
return "M";
|
||||||
} else if (s >= 10*K) {
|
} else if (s >= 10*K) {
|
||||||
@ -188,17 +193,22 @@ inline const char* proper_unit_for_byte_size(size_t s) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline size_t byte_size_in_proper_unit(size_t s) {
|
template <class T>
|
||||||
|
inline T byte_size_in_proper_unit(T s) {
|
||||||
|
#ifdef _LP64
|
||||||
|
if (s >= 10*G) {
|
||||||
|
return (T)(s/G);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
if (s >= 10*M) {
|
if (s >= 10*M) {
|
||||||
return s/M;
|
return (T)(s/M);
|
||||||
} else if (s >= 10*K) {
|
} else if (s >= 10*K) {
|
||||||
return s/K;
|
return (T)(s/K);
|
||||||
} else {
|
} else {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
// VM type definitions
|
// VM type definitions
|
||||||
|
|
||||||
|
@ -160,3 +160,4 @@ ddfe5562f61f54ed2121ac0c73b688b94f3e66b5 jdk8-b32
|
|||||||
45da9cb055ee258dc09e69c1718e27eadea38e45 jdk8-b36
|
45da9cb055ee258dc09e69c1718e27eadea38e45 jdk8-b36
|
||||||
9e82ac15ab80370d6e021aea7b98c7c9626adb5e jdk8-b37
|
9e82ac15ab80370d6e021aea7b98c7c9626adb5e jdk8-b37
|
||||||
c45f3509a70796c54b48f32910d1caf435763416 jdk8-b38
|
c45f3509a70796c54b48f32910d1caf435763416 jdk8-b38
|
||||||
|
b6f52911752110a2889681923992c7a0baa52ccc jdk8-b39
|
||||||
|
@ -65,12 +65,8 @@ FILES_export = \
|
|||||||
com/apple/laf/ScreenMenuPropertyHandler.java \
|
com/apple/laf/ScreenMenuPropertyHandler.java \
|
||||||
com/apple/laf/ScreenMenuPropertyListener.java
|
com/apple/laf/ScreenMenuPropertyListener.java
|
||||||
|
|
||||||
#RESOURCE_BUNDLES_COMPILED_PROPERTIES += \
|
RESOURCE_BUNDLES_COMPILED_PROPERTIES += \
|
||||||
# com/apple/laf/resources/aqua.properties \
|
com/apple/laf/resources/aqua.properties
|
||||||
# com/apple/laf/resources/aqua_de.properties \
|
|
||||||
# com/apple/laf/resources/aqua_fr.properties \
|
|
||||||
# com/apple/laf/resources/aqua_ja.properties
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Rules
|
# Rules
|
||||||
|
@ -139,7 +139,7 @@ ifndef OPENJDK
|
|||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath \
|
JAVAHFLAGS = -bootclasspath \
|
||||||
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
include $(BUILDDIR)/common/Library.gmk
|
include $(BUILDDIR)/common/Library.gmk
|
||||||
|
@ -197,6 +197,10 @@ $(GENSRCDIR)/%.java: $(SHARE_SRC)/classes/%.properties
|
|||||||
$(add-property-java-file)
|
$(add-property-java-file)
|
||||||
$(GENSRCDIR)/%.java: $(GENSRCDIR)/%.properties
|
$(GENSRCDIR)/%.java: $(GENSRCDIR)/%.properties
|
||||||
$(add-property-java-file)
|
$(add-property-java-file)
|
||||||
|
ifdef PLATFORM_SRC_MACOS
|
||||||
|
$(GENSRCDIR)/%.java: $(PLATFORM_SRC_MACOS)/classes/%.properties
|
||||||
|
$(add-property-java-file)
|
||||||
|
endif
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
$(GENSRCDIR)/%.java: $(CLOSED_PLATFORM_SRC)/classes/%.properties
|
$(GENSRCDIR)/%.java: $(CLOSED_PLATFORM_SRC)/classes/%.properties
|
||||||
$(add-property-java-file)
|
$(add-property-java-file)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -139,7 +139,7 @@ JAVACFLAGS += $(JAVAC_LINT_OPTIONS)
|
|||||||
# built implicitly/explicitly.
|
# built implicitly/explicitly.
|
||||||
#
|
#
|
||||||
ifeq ($(wildcard $(SHARE_SRC)/classes/javax/crypto/Cipher.java),)
|
ifeq ($(wildcard $(SHARE_SRC)/classes/javax/crypto/Cipher.java),)
|
||||||
JCEFLAGS = $(CLASSPATH_SEPARATOR)$(LIBDIR)/jce.jar
|
JCE_PATH = $(CLASSPATH_SEPARATOR)$(LIBDIR)/jce.jar
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Add the source level
|
# Add the source level
|
||||||
@ -152,11 +152,11 @@ TARGET_CLASS_VERSION = 7
|
|||||||
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
||||||
JAVACFLAGS += $(CLASS_VERSION)
|
JAVACFLAGS += $(CLASS_VERSION)
|
||||||
JAVACFLAGS += -encoding ascii
|
JAVACFLAGS += -encoding ascii
|
||||||
JAVACFLAGS += "-Xbootclasspath:$(CLASSBINDIR)$(JCEFLAGS)"
|
JAVACFLAGS += "-Xbootclasspath:$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
JAVACFLAGS += $(OTHER_JAVACFLAGS)
|
JAVACFLAGS += $(OTHER_JAVACFLAGS)
|
||||||
|
|
||||||
# Needed for javah
|
# Needed for javah
|
||||||
JAVAHFLAGS += -bootclasspath "$(CLASSBINDIR)$(JCEFLAGS)"
|
JAVAHFLAGS += -bootclasspath "$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
# Needed for javadoc to ensure it builds documentation
|
# Needed for javadoc to ensure it builds documentation
|
||||||
# against the newly built classes
|
# against the newly built classes
|
||||||
|
@ -261,8 +261,7 @@ ifndef BUILD_CLIENT_ONLY
|
|||||||
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
||||||
# the import JDK may not contain the target of the symlink
|
# the import JDK may not contain the target of the symlink
|
||||||
ifneq ($(wildcard $(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/$(LIBJSIG_DIZ_NAME)),)
|
ifneq ($(wildcard $(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/$(LIBJSIG_DIZ_NAME)),)
|
||||||
# check for the .diz file, but create the .debuginfo link
|
IMPORT_LIST += $(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_DIZ_NAME)
|
||||||
IMPORT_LIST += $(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME)
|
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
# the import JDK may not contain the target of the symlink
|
# the import JDK may not contain the target of the symlink
|
||||||
@ -319,8 +318,7 @@ ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
|
|||||||
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
||||||
# the import JDK may not contain the target of the symlink
|
# the import JDK may not contain the target of the symlink
|
||||||
ifneq ($(wildcard $(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/$(LIBJSIG_DIZ_NAME)),)
|
ifneq ($(wildcard $(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/$(LIBJSIG_DIZ_NAME)),)
|
||||||
# check for the .diz file, but create the .debuginfo link
|
IMPORT_LIST += $(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DIZ_NAME)
|
||||||
IMPORT_LIST += $(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME)
|
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
# the import JDK may not contain the target of the symlink
|
# the import JDK may not contain the target of the symlink
|
||||||
@ -472,11 +470,24 @@ $(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_NAME):
|
|||||||
$(call install-sym-link, ../$(LIBJSIG_NAME))
|
$(call install-sym-link, ../$(LIBJSIG_NAME))
|
||||||
|
|
||||||
ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
|
ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
|
||||||
# we don't create a symlink to a libjsig.diz file
|
# We don't create a symlink to a libjsig.diz file, but we do put
|
||||||
|
# the libjsig.debuginfo symlink into a libjsig.diz file. The aurora
|
||||||
|
# system does not like dangling symlinks.
|
||||||
|
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
||||||
|
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DIZ_NAME) \
|
||||||
|
$(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_DIZ_NAME):
|
||||||
|
@$(prep-target)
|
||||||
|
$(LN) -s ../$(LIBJSIG_DEBUGINFO_NAME) $(@D)/$(LIBJSIG_DEBUGINFO_NAME)
|
||||||
|
( $(CD) $(@D) ; \
|
||||||
|
$(ZIPEXE) -y $(LIBJSIG_DIZ_NAME) $(LIBJSIG_DEBUGINFO_NAME) ; \
|
||||||
|
$(RM) $(LIBJSIG_DEBUGINFO_NAME) ; \
|
||||||
|
)
|
||||||
|
else
|
||||||
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME) \
|
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME) \
|
||||||
$(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME):
|
$(LIB_LOCATION)/$(SERVER_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME):
|
||||||
@$(prep-target)
|
@$(prep-target)
|
||||||
$(call install-sym-link, ../$(LIBJSIG_DEBUGINFO_NAME))
|
$(call install-sym-link, ../$(LIBJSIG_DEBUGINFO_NAME))
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_NAME):
|
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_NAME):
|
||||||
@ -484,10 +495,22 @@ $(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_NAME):
|
|||||||
$(call install-sym-link, ../$(LIBJSIG_NAME))
|
$(call install-sym-link, ../$(LIBJSIG_NAME))
|
||||||
|
|
||||||
ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
|
ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
|
||||||
# we don't create a symlink to a libjsig.diz file
|
# We don't create a symlink to a libjsig.diz file, but we do put
|
||||||
|
# the libjsig.debuginfo symlink into a libjsig.diz file. The aurora
|
||||||
|
# system does not like dangling symlinks.
|
||||||
|
ifeq ($(ZIP_DEBUGINFO_FILES),1)
|
||||||
|
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DIZ_NAME):
|
||||||
|
@$(prep-target)
|
||||||
|
$(LN) -s ../$(LIBJSIG_DEBUGINFO_NAME) $(@D)/$(LIBJSIG_DEBUGINFO_NAME)
|
||||||
|
( $(CD) $(@D) ; \
|
||||||
|
$(ZIPEXE) -y $(LIBJSIG_DIZ_NAME) $(LIBJSIG_DEBUGINFO_NAME) ; \
|
||||||
|
$(RM) $(LIBJSIG_DEBUGINFO_NAME) ; \
|
||||||
|
)
|
||||||
|
else
|
||||||
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME):
|
$(LIB_LOCATION)/$(CLIENT_LOCATION)/$(LIBJSIG_DEBUGINFO_NAME):
|
||||||
@$(prep-target)
|
@$(prep-target)
|
||||||
$(call install-sym-link, ../$(LIBJSIG_DEBUGINFO_NAME))
|
$(call install-sym-link, ../$(LIBJSIG_DEBUGINFO_NAME))
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -160,7 +160,7 @@ ifeq ($(NATIVE_ECC_AVAILABLE), true)
|
|||||||
$(PKGDIR)/ECKeyPairGenerator.java
|
$(PKGDIR)/ECKeyPairGenerator.java
|
||||||
|
|
||||||
JAVAHFLAGS = -bootclasspath \
|
JAVAHFLAGS = -bootclasspath \
|
||||||
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -150,7 +150,7 @@ OTHER_INCLUDES += \
|
|||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath \
|
JAVAHFLAGS = -bootclasspath \
|
||||||
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -151,7 +151,7 @@ OTHER_INCLUDES += \
|
|||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath \
|
JAVAHFLAGS = -bootclasspath \
|
||||||
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -139,7 +139,7 @@ ifndef OPENJDK
|
|||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath \
|
JAVAHFLAGS = -bootclasspath \
|
||||||
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
include $(BUILDDIR)/common/Library.gmk
|
include $(BUILDDIR)/common/Library.gmk
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -141,7 +141,7 @@ JAVACFLAGS += $(JAVAC_LINT_OPTIONS)
|
|||||||
# built implicitly/explicitly.
|
# built implicitly/explicitly.
|
||||||
#
|
#
|
||||||
ifeq ($(wildcard $(SHARE_SRC)/classes/javax/crypto/Cipher.java),)
|
ifeq ($(wildcard $(SHARE_SRC)/classes/javax/crypto/Cipher.java),)
|
||||||
JCEFLAGS = $(CLASSPATH_SEPARATOR)$(LIBDIR)/jce.jar
|
JCE_PATH = $(CLASSPATH_SEPARATOR)$(LIBDIR)/jce.jar
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Add the source level
|
# Add the source level
|
||||||
@ -154,11 +154,11 @@ TARGET_CLASS_VERSION = 7
|
|||||||
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
||||||
JAVACFLAGS += $(CLASS_VERSION)
|
JAVACFLAGS += $(CLASS_VERSION)
|
||||||
JAVACFLAGS += -encoding ascii
|
JAVACFLAGS += -encoding ascii
|
||||||
JAVACFLAGS += "-Xbootclasspath:$(CLASSBINDIR)$(JCEFLAGS)"
|
JAVACFLAGS += "-Xbootclasspath:$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
JAVACFLAGS += $(OTHER_JAVACFLAGS)
|
JAVACFLAGS += $(OTHER_JAVACFLAGS)
|
||||||
|
|
||||||
# Needed for javah
|
# Needed for javah
|
||||||
JAVAHFLAGS += -bootclasspath "$(CLASSBINDIR)$(JCEFLAGS)"
|
JAVAHFLAGS += -bootclasspath "$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
# Needed for javadoc to ensure it builds documentation
|
# Needed for javadoc to ensure it builds documentation
|
||||||
# against the newly built classes
|
# against the newly built classes
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -159,7 +159,8 @@ ifeq ($(NATIVE_ECC_AVAILABLE), true)
|
|||||||
$(PKGDIR)/ECDSASignature.java \
|
$(PKGDIR)/ECDSASignature.java \
|
||||||
$(PKGDIR)/ECKeyPairGenerator.java
|
$(PKGDIR)/ECKeyPairGenerator.java
|
||||||
|
|
||||||
JAVAHFLAGS += -Xbootclasspath/p:$(CLASSDESTDIR)
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
#
|
#
|
||||||
# C and C++ files
|
# C and C++ files
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -149,7 +149,8 @@ OTHER_INCLUDES += \
|
|||||||
# Rules
|
# Rules
|
||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS += -Xbootclasspath/p:$(CLASSDESTDIR)
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -150,7 +150,8 @@ OTHER_INCLUDES += \
|
|||||||
# Rules
|
# Rules
|
||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath "$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)$(JCE_PATH)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@ import java.awt.image.BufferedImage;
|
|||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.border.Border;
|
import javax.swing.border.Border;
|
||||||
|
import javax.swing.plaf.UIResource;
|
||||||
import javax.swing.plaf.basic.BasicHTML;
|
import javax.swing.plaf.basic.BasicHTML;
|
||||||
import javax.swing.text.View;
|
import javax.swing.text.View;
|
||||||
|
|
||||||
@ -76,8 +77,11 @@ public abstract class AquaButtonLabeledUI extends AquaButtonToggleUI implements
|
|||||||
protected void setThemeBorder(final AbstractButton b) {
|
protected void setThemeBorder(final AbstractButton b) {
|
||||||
super.setThemeBorder(b);
|
super.setThemeBorder(b);
|
||||||
|
|
||||||
// Set the correct border
|
Border border = b.getBorder();
|
||||||
b.setBorder(AquaButtonBorder.getBevelButtonBorder());
|
if (border == null || border instanceof UIResource) {
|
||||||
|
// Set the correct border
|
||||||
|
b.setBorder(AquaButtonBorder.getBevelButtonBorder());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract AquaButtonBorder getPainter();
|
protected abstract AquaButtonBorder getPainter();
|
||||||
|
@ -250,6 +250,7 @@ public class AquaLookAndFeel extends BasicLookAndFeel {
|
|||||||
*/
|
*/
|
||||||
private void initResourceBundle(final UIDefaults table) {
|
private void initResourceBundle(final UIDefaults table) {
|
||||||
table.setDefaultLocale(Locale.getDefault());
|
table.setDefaultLocale(Locale.getDefault());
|
||||||
|
table.addResourceBundle(PKG_PREFIX + "resources.aqua");
|
||||||
try {
|
try {
|
||||||
final ResourceBundle aquaProperties = MacOSXResourceBundle.getMacResourceBundle(PKG_PREFIX + "resources.aqua");
|
final ResourceBundle aquaProperties = MacOSXResourceBundle.getMacResourceBundle(PKG_PREFIX + "resources.aqua");
|
||||||
final Enumeration<String> propertyKeys = aquaProperties.getKeys();
|
final Enumeration<String> propertyKeys = aquaProperties.getKeys();
|
||||||
@ -259,7 +260,6 @@ public class AquaLookAndFeel extends BasicLookAndFeel {
|
|||||||
table.put(key, aquaProperties.getString(key));
|
table.put(key, aquaProperties.getString(key));
|
||||||
}
|
}
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
table.addResourceBundle(PKG_PREFIX + "resources.aqua");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -318,7 +318,7 @@ public class AquaTabbedPaneUI extends AquaTabbedPaneCopyFromBasicUI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// not for the scrolling tabs
|
// not for the scrolling tabs
|
||||||
if (tabIndex >= 0) {
|
if (component == null && tabIndex >= 0) {
|
||||||
paintTitle(g2d, font, metrics, textRect, tabIndex, title);
|
paintTitle(g2d, font, metrics, textRect, tabIndex, title);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,45 +36,45 @@
|
|||||||
# support.
|
# support.
|
||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
FileChooser.fileDescriptionText=Generic File
|
FileChooser.fileDescription.textAndMnemonic=Generic File
|
||||||
FileChooser.directoryDescriptionText=Directory
|
FileChooser.directoryDescription.textAndMnemonic=Directory
|
||||||
FileChooser.newFolderErrorText=Error occured during folder creation
|
FileChooser.newFolderError.textAndMnemonic=Error occured during folder creation
|
||||||
FileChooser.newFolderErrorSeparator= :
|
FileChooser.newFolderErrorSeparator= :
|
||||||
FileChooser.acceptAllFileFilterText=All Files
|
FileChooser.acceptAllFileFilter.textAndMnemonic=All Files
|
||||||
FileChooser.cancelButtonText=Cancel
|
FileChooser.cancelButton.textAndMnemonic=Cancel
|
||||||
FileChooser.saveButtonText=Save
|
FileChooser.saveButton.textAndMnemonic=Save
|
||||||
FileChooser.openButtonText=Open
|
FileChooser.openButton.textAndMnemonic=Open
|
||||||
FileChooser.saveDialogTitleText=Save
|
FileChooser.saveDialogTitle.textAndMnemonic=Save
|
||||||
FileChooser.openDialogTitleText=Open
|
FileChooser.openDialogTitle.textAndMnemonic=Open
|
||||||
FileChooser.updateButtonText=Update
|
FileChooser.updateButton.textAndMnemonic=Update
|
||||||
FileChooser.helpButtonText=Help
|
FileChooser.helpButton.textAndMnemonic=Help
|
||||||
FileChooser.directoryOpenButtonText=Open
|
FileChooser.directoryOpenButton.textAndMnemonic=Open
|
||||||
|
|
||||||
# File Size Units
|
# File Size Units
|
||||||
FileChooser.fileSizeKiloBytes={0} KB
|
FileChooser.fileSizeKiloBytes={0} KB
|
||||||
FileChooser.fileSizeMegaBytes={0} MB
|
FileChooser.fileSizeMegaBytes={0} MB
|
||||||
FileChooser.fileSizeGigaBytes={0} GB
|
FileChooser.fileSizeGigaBytes={0} GB
|
||||||
|
|
||||||
// Mac-specific strings
|
# Mac-specific strings
|
||||||
FileChooser.saveTitleText=Save
|
FileChooser.saveTitle.textAndMnemonic=Save
|
||||||
FileChooser.openTitleText=Open
|
FileChooser.openTitle.textAndMnemonic=Open
|
||||||
FileChooser.newFolderExistsErrorText=That name is already taken
|
FileChooser.newFolderExistsError.textAndMnemonic=That name is already taken
|
||||||
FileChooser.chooseButtonText=Choose
|
FileChooser.chooseButton.textAndMnemonic=Choose
|
||||||
|
|
||||||
FileChooser.newFolderButtonText=New Folder
|
FileChooser.newFolderButton.textAndMnemonic=New Folder
|
||||||
FileChooser.newFolderTitleText=New Folder
|
FileChooser.newFolderTitle.textAndMnemonic=New Folder
|
||||||
FileChooser.fileNameLabelText=File:
|
FileChooser.fileNameLabel.textAndMnemonic=File:
|
||||||
FileChooser.saveDialogFileNameLabelText=Save As:
|
FileChooser.saveDialogFileNameLabel.textAndMnemonic=Save As:
|
||||||
FileChooser.filesOfTypeLabelText=File Format:
|
FileChooser.filesOfTypeLabel.textAndMnemonic=File Format:
|
||||||
|
|
||||||
FileChooser.desktopName=Desktop
|
FileChooser.desktopName=Desktop
|
||||||
FileChooser.newFolderPromptText=Name of new folder:
|
FileChooser.newFolderPrompt.textAndMnemonic=Name of new folder:
|
||||||
FileChooser.untitledFolderName=untitled folder
|
FileChooser.untitledFolderName=untitled folder
|
||||||
FileChooser.untitledFileName=untitled
|
FileChooser.untitledFileName=untitled
|
||||||
FileChooser.createButtonText=Create
|
FileChooser.createButton.textAndMnemonic=Create
|
||||||
|
|
||||||
FileChooser.byDateText=Date Modified
|
FileChooser.byDate.textAndMnemonic=Date Modified
|
||||||
FileChooser.byNameText=Name
|
FileChooser.by.textAndMnemonic=Name
|
||||||
FileChooser.newFolderAccessibleName=New Folder
|
FileChooser.newFolderAccessibleName=New Folder
|
||||||
|
|
||||||
FileChooser.mac.newFolder=untitled folder
|
FileChooser.mac.newFolder=untitled folder
|
||||||
@ -82,76 +82,54 @@ FileChooser.mac.newFolder.subsequent=untitled folder {0}
|
|||||||
|
|
||||||
|
|
||||||
############ COLOR CHOOSER STRINGS #############
|
############ COLOR CHOOSER STRINGS #############
|
||||||
ColorChooser.previewText=Preview
|
ColorChooser.preview.textAndMnemonic=Preview
|
||||||
ColorChooser.okText=OK
|
ColorChooser.ok.textAndMnemonic=OK
|
||||||
ColorChooser.cancelText=Cancel
|
ColorChooser.cancel.textAndMnemonic=Cancel
|
||||||
ColorChooser.resetText=Reset
|
ColorChooser.reset.textAndMnemonic=&Reset
|
||||||
# VK_XXX constant for 'ColorChooser.resetText' button to make mnemonic
|
ColorChooser.sample.textAndMnemonic=Sample Text Sample Text
|
||||||
ColorChooser.resetMnemonic=82
|
ColorChooser.swatches.textAndMnemonic=&Swatches
|
||||||
ColorChooser.sampleText=Sample Text Sample Text
|
ColorChooser.swatchesRecent.textAndMnemonic=Recent:
|
||||||
ColorChooser.swatchesNameText=Swatches
|
ColorChooser.hsb.textAndMnemonic=&HSB
|
||||||
ColorChooser.swatchesMnemonic=83
|
ColorChooser.hsbHue.textAndMnemonic=H
|
||||||
ColorChooser.swatchesDisplayedMnemonicIndex=0
|
ColorChooser.hsbSaturation.textAndMnemonic=S
|
||||||
ColorChooser.swatchesRecentText=Recent:
|
ColorChooser.hsbBrightness.textAndMnemonic=B
|
||||||
ColorChooser.hsbNameText=HSB
|
ColorChooser.hsbRed.textAndMnemonic=R
|
||||||
# Each of the ColorChooser types can define a mnemonic, as a KeyEvent.VK_XXX
|
ColorChooser.hsbGreen.textAndMnemonic=G
|
||||||
# constant, and an index into the text to render the mnemonic as. The
|
ColorChooser.hsbBlue.textAndMnemonic=B
|
||||||
# mnemonic is xxxMnemonic and the index of the character to underline is
|
ColorChooser.rgb.textAndMnemonic=R&GB
|
||||||
# xxxDisplayedMnemonicIndex.
|
ColorChooser.rgbRed.textAndMnemonic=Re&d
|
||||||
ColorChooser.hsbMnemonic=72
|
ColorChooser.rgbGreen.textAndMnemonic=Gree&n
|
||||||
ColorChooser.hsbDisplayedMnemonicIndex=0
|
ColorChooser.rgbBlue.textAndMnemonic=&Blue
|
||||||
ColorChooser.hsbHueText=H
|
|
||||||
ColorChooser.hsbSaturationText=S
|
|
||||||
ColorChooser.hsbBrightnessText=B
|
|
||||||
ColorChooser.hsbRedText=R
|
|
||||||
ColorChooser.hsbGreenText=G
|
|
||||||
ColorChooser.hsbBlueText=B
|
|
||||||
ColorChooser.rgbNameText=RGB
|
|
||||||
ColorChooser.rgbMnemonic=71
|
|
||||||
ColorChooser.rgbDisplayedMnemonicIndex=1
|
|
||||||
ColorChooser.rgbRedText=Red
|
|
||||||
ColorChooser.rgbRedMnemonic=68
|
|
||||||
ColorChooser.rgbGreenText=Green
|
|
||||||
ColorChooser.rgbGreenMnemonic=78
|
|
||||||
ColorChooser.rgbBlueText=Blue
|
|
||||||
ColorChooser.rgbBlueMnemonic=66
|
|
||||||
|
|
||||||
############ OPTION PANE STRINGS #############
|
############ OPTION PANE STRINGS #############
|
||||||
# Mnemonic keys correspond to KeyEvent.VK_XXX constant
|
|
||||||
# We only define mnemonics for YES/NO, but for completeness you can
|
# We only define mnemonics for YES/NO, but for completeness you can
|
||||||
# define mnemonics for any of the buttons.
|
# define mnemonics for any of the buttons.
|
||||||
OptionPane.yesButtonText=Yes
|
OptionPane.yesButton.textAndMnemonic=&Yes
|
||||||
OptionPane.yesButtonMnemonic=89
|
OptionPane.noButton.textAndMnemonic=&No
|
||||||
OptionPane.noButtonText=No
|
OptionPane.okButton.textAndMnemonic=OK
|
||||||
OptionPane.noButtonMnemonic=78
|
OptionPane.cancelButton.textAndMnemonic=Cancel
|
||||||
OptionPane.okButtonText=OK
|
OptionPane.title.textAndMnemonic=Select an Option
|
||||||
OptionPane.okButtonMnemonic=0
|
|
||||||
OptionPane.cancelButtonText=Cancel
|
|
||||||
OptionPane.cancelButtonMnemonic=0
|
|
||||||
OptionPane.titleText=Select an Option
|
|
||||||
# Title for the dialog for the showInputDialog methods. Only used if
|
# Title for the dialog for the showInputDialog methods. Only used if
|
||||||
# the developer uses one of the variants that doesn't take a title.
|
# the developer uses one of the variants that doesn't take a title.
|
||||||
OptionPane.inputDialogTitle=Input
|
OptionPane.inputDialog.titleAndMnemonic=Input
|
||||||
# Title for the dialog for the showMessageDialog methods. Only used if
|
# Title for the dialog for the showMessageDialog methods. Only used if
|
||||||
# the developer uses one of the variants that doesn't take a title.
|
# the developer uses one of the variants that doesn't take a title.
|
||||||
OptionPane.messageDialogTitle=Message
|
OptionPane.messageDialog.titleAndMnemonic=Message
|
||||||
|
|
||||||
############ Printing Dialog Strings ############
|
############ Printing Dialog Strings ############
|
||||||
PrintingDialog.titleProgressText=Printing
|
PrintingDialog.titleProgress.textAndMnemonic=Printing
|
||||||
PrintingDialog.titleAbortingText=Printing (Aborting)
|
PrintingDialog.titleAborting.textAndMnemonic=Printing (Aborting)
|
||||||
|
|
||||||
PrintingDialog.contentInitialText=Printing in progress...
|
PrintingDialog.contentInitial.textAndMnemonic=Printing in progress...
|
||||||
|
|
||||||
# The following string will be formatted by a MessageFormat
|
# The following string will be formatted by a MessageFormat
|
||||||
# and {0} will be replaced by page number being printed
|
# and {0} will be replaced by page number being printed
|
||||||
PrintingDialog.contentProgressText=Printed page {0}...
|
PrintingDialog.contentProgress.textAndMnemonic=Printed page {0}...
|
||||||
|
|
||||||
PrintingDialog.contentAbortingText=Printing aborting...
|
PrintingDialog.contentAborting.textAndMnemonic=Printing aborting...
|
||||||
|
|
||||||
PrintingDialog.abortButtonText=Abort
|
PrintingDialog.abortButton.textAndMnemonic=&Abort
|
||||||
PrintingDialog.abortButtonMnemonic=65
|
PrintingDialog.abortButtonToolTip.textAndMnemonic=Abort Printing
|
||||||
PrintingDialog.abortButtonDisplayedMnemonicIndex=0
|
|
||||||
PrintingDialog.abortButtonToolTipText=Abort Printing
|
|
||||||
|
|
||||||
############ Internal Frame Strings ############
|
############ Internal Frame Strings ############
|
||||||
InternalFrame.iconButtonToolTip=Minimize
|
InternalFrame.iconButtonToolTip=Minimize
|
||||||
@ -160,42 +138,42 @@ InternalFrame.restoreButtonToolTip=Restore
|
|||||||
InternalFrame.closeButtonToolTip=Close
|
InternalFrame.closeButtonToolTip=Close
|
||||||
|
|
||||||
############ Internal Frame Title Pane Strings ############
|
############ Internal Frame Title Pane Strings ############
|
||||||
InternalFrameTitlePane.restoreButtonText=Restore
|
InternalFrameTitlePane.restoreButton.textAndMnemonic=Restore
|
||||||
InternalFrameTitlePane.moveButtonText=Move
|
InternalFrameTitlePane.moveButton.textAndMnemonic=Move
|
||||||
InternalFrameTitlePane.sizeButtonText=Size
|
InternalFrameTitlePane.sizeButton.textAndMnemonic=Size
|
||||||
InternalFrameTitlePane.minimizeButtonText=Minimize
|
InternalFrameTitlePane.minimizeButton.textAndMnemonic=Minimize
|
||||||
InternalFrameTitlePane.maximizeButtonText=Maximize
|
InternalFrameTitlePane.maximizeButton.textAndMnemonic=Maximize
|
||||||
InternalFrameTitlePane.closeButtonText=Close
|
InternalFrameTitlePane.closeButton.textAndMnemonic=Close
|
||||||
|
|
||||||
############ Text strings #############
|
############ Text strings #############
|
||||||
# Used for html forms
|
# Used for html forms
|
||||||
FormView.submitButtonText=Submit Query
|
FormView.submitButton.textAndMnemonic=Submit Query
|
||||||
FormView.resetButtonText=Reset
|
FormView.resetButton.textAndMnemonic=Reset
|
||||||
FormView.browseFileButtonText=Browse...
|
FormView.browseFileButton.textAndMnemonic=Browse...
|
||||||
|
|
||||||
############ Abstract Document Strings ############
|
############ Abstract Document Strings ############
|
||||||
AbstractDocument.styleChangeText=style change
|
AbstractDocument.styleChange.textAndMnemonic=style change
|
||||||
AbstractDocument.additionText=addition
|
AbstractDocument.addition.textAndMnemonic=addition
|
||||||
AbstractDocument.deletionText=deletion
|
AbstractDocument.deletion.textAndMnemonic=deletion
|
||||||
AbstractDocument.undoText=Undo
|
AbstractDocument.undo.textAndMnemonic=Undo
|
||||||
AbstractDocument.redoText=Redo
|
AbstractDocument.redo.textAndMnemonic=Redo
|
||||||
|
|
||||||
############ Abstract Button Strings ############
|
############ Abstract Button Strings ############
|
||||||
AbstractButton.clickText=click
|
AbstractButton.click.textAndMnemonic=click
|
||||||
|
|
||||||
############ Abstract Undoable Edit Strings ############
|
############ Abstract Undoable Edit Strings ############
|
||||||
AbstractUndoableEdit.undoText=Undo
|
AbstractUndoableEdit.undo.textAndMnemonic=Undo
|
||||||
AbstractUndoableEdit.redoText=Redo
|
AbstractUndoableEdit.redo.textAndMnemonic=Redo
|
||||||
|
|
||||||
############ Combo Box Strings ############
|
############ Combo Box Strings ############
|
||||||
ComboBox.togglePopupText=togglePopup
|
ComboBox.togglePopup.textAndMnemonic=togglePopup
|
||||||
|
|
||||||
############ Progress Monitor Strings ############
|
############ Progress Monitor Strings ############
|
||||||
ProgressMonitor.progressText=Progress...
|
ProgressMonitor.progress.textAndMnemonic=Progress...
|
||||||
|
|
||||||
############ Split Pane Strings ############
|
############ Split Pane Strings ############
|
||||||
SplitPane.leftButtonText=left button
|
SplitPane.leftButton.textAndMnemonic=left button
|
||||||
SplitPane.rightButtonText=right button
|
SplitPane.rightButton.textAndMnemonic=right button
|
||||||
# Used for Isindex
|
# Used for Isindex
|
||||||
IsindexView.prompt=This is a searchable index. Enter search keywords:
|
IsindexView.prompt=This is a searchable index. Enter search keywords:
|
||||||
|
|
||||||
|
@ -135,18 +135,21 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
|
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected void putSpi(String key, String value)
|
protected void putSpi(String key, String value)
|
||||||
{
|
{
|
||||||
file.addKeyToNode(path, key, value);
|
file.addKeyToNode(path, key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected String getSpi(String key)
|
protected String getSpi(String key)
|
||||||
{
|
{
|
||||||
return file.getKeyFromNode(path, key);
|
return file.getKeyFromNode(path, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected void removeSpi(String key)
|
protected void removeSpi(String key)
|
||||||
{
|
{
|
||||||
Objects.requireNonNull(key, "Specified key cannot be null");
|
Objects.requireNonNull(key, "Specified key cannot be null");
|
||||||
@ -155,6 +158,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
|
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected void removeNodeSpi()
|
protected void removeNodeSpi()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -174,6 +178,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
|
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected String[] childrenNamesSpi()
|
protected String[] childrenNamesSpi()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -183,6 +188,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected String[] keysSpi()
|
protected String[] keysSpi()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -192,6 +198,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected AbstractPreferences childSpi(String name)
|
protected AbstractPreferences childSpi(String name)
|
||||||
{
|
{
|
||||||
// Add to parent's child list here and disallow sync
|
// Add to parent's child list here and disallow sync
|
||||||
@ -203,6 +210,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences override
|
// AbstractPreferences override
|
||||||
|
@Override
|
||||||
public void flush()
|
public void flush()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -217,6 +225,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected void flushSpi()
|
protected void flushSpi()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -224,6 +233,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences override
|
// AbstractPreferences override
|
||||||
|
@Override
|
||||||
public void sync()
|
public void sync()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
@ -244,6 +254,7 @@ class MacOSXPreferences extends AbstractPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// AbstractPreferences implementation
|
// AbstractPreferences implementation
|
||||||
|
@Override
|
||||||
protected void syncSpi()
|
protected void syncSpi()
|
||||||
throws BackingStoreException
|
throws BackingStoreException
|
||||||
{
|
{
|
||||||
|
@ -26,10 +26,12 @@
|
|||||||
package java.util.prefs;
|
package java.util.prefs;
|
||||||
|
|
||||||
class MacOSXPreferencesFactory implements PreferencesFactory {
|
class MacOSXPreferencesFactory implements PreferencesFactory {
|
||||||
|
@Override
|
||||||
public Preferences userRoot() {
|
public Preferences userRoot() {
|
||||||
return MacOSXPreferences.getUserRoot();
|
return MacOSXPreferences.getUserRoot();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Preferences systemRoot() {
|
public Preferences systemRoot() {
|
||||||
return MacOSXPreferences.getSystemRoot();
|
return MacOSXPreferences.getSystemRoot();
|
||||||
}
|
}
|
||||||
|
@ -101,9 +101,10 @@ class MacOSXPreferencesFile {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Maps string -> weak reference to MacOSXPreferencesFile
|
// Maps string -> weak reference to MacOSXPreferencesFile
|
||||||
private static HashMap cachedFiles = null;
|
private static HashMap<String, WeakReference<MacOSXPreferencesFile>>
|
||||||
|
cachedFiles;
|
||||||
// Files that may have unflushed changes
|
// Files that may have unflushed changes
|
||||||
private static HashSet changedFiles = null;
|
private static HashSet<MacOSXPreferencesFile> changedFiles;
|
||||||
|
|
||||||
|
|
||||||
// Timer and pending sync and flush tasks (which are both scheduled
|
// Timer and pending sync and flush tasks (which are both scheduled
|
||||||
@ -136,13 +137,14 @@ class MacOSXPreferencesFile {
|
|||||||
{
|
{
|
||||||
MacOSXPreferencesFile result = null;
|
MacOSXPreferencesFile result = null;
|
||||||
|
|
||||||
if (cachedFiles == null) cachedFiles = new HashMap();
|
if (cachedFiles == null)
|
||||||
|
cachedFiles = new HashMap<>();
|
||||||
|
|
||||||
String hashkey =
|
String hashkey =
|
||||||
newName + String.valueOf(isUser);
|
newName + String.valueOf(isUser);
|
||||||
WeakReference hashvalue = (WeakReference)cachedFiles.get(hashkey);
|
WeakReference<MacOSXPreferencesFile> hashvalue = cachedFiles.get(hashkey);
|
||||||
if (hashvalue != null) {
|
if (hashvalue != null) {
|
||||||
result = (MacOSXPreferencesFile)hashvalue.get();
|
result = hashvalue.get();
|
||||||
}
|
}
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
// Java user node == CF current user, any host
|
// Java user node == CF current user, any host
|
||||||
@ -150,7 +152,7 @@ class MacOSXPreferencesFile {
|
|||||||
result = new MacOSXPreferencesFile(newName,
|
result = new MacOSXPreferencesFile(newName,
|
||||||
isUser ? cfCurrentUser : cfAnyUser,
|
isUser ? cfCurrentUser : cfAnyUser,
|
||||||
isUser ? cfAnyHost : cfCurrentHost);
|
isUser ? cfAnyHost : cfCurrentHost);
|
||||||
cachedFiles.put(hashkey, new WeakReference(result));
|
cachedFiles.put(hashkey, new WeakReference<MacOSXPreferencesFile>(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't schedule this file for flushing until some nodes or
|
// Don't schedule this file for flushing until some nodes or
|
||||||
@ -171,10 +173,11 @@ class MacOSXPreferencesFile {
|
|||||||
boolean ok = true;
|
boolean ok = true;
|
||||||
|
|
||||||
if (cachedFiles != null && !cachedFiles.isEmpty()) {
|
if (cachedFiles != null && !cachedFiles.isEmpty()) {
|
||||||
Iterator iter = cachedFiles.values().iterator();
|
Iterator<WeakReference<MacOSXPreferencesFile>> iter =
|
||||||
|
cachedFiles.values().iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
WeakReference ref = (WeakReference)iter.next();
|
WeakReference<MacOSXPreferencesFile> ref = iter.next();
|
||||||
MacOSXPreferencesFile f = (MacOSXPreferencesFile)ref.get();
|
MacOSXPreferencesFile f = ref.get();
|
||||||
if (f != null) {
|
if (f != null) {
|
||||||
if (!f.synchronize()) ok = false;
|
if (!f.synchronize()) ok = false;
|
||||||
} else {
|
} else {
|
||||||
@ -202,10 +205,11 @@ class MacOSXPreferencesFile {
|
|||||||
static synchronized boolean syncUser() {
|
static synchronized boolean syncUser() {
|
||||||
boolean ok = true;
|
boolean ok = true;
|
||||||
if (cachedFiles != null && !cachedFiles.isEmpty()) {
|
if (cachedFiles != null && !cachedFiles.isEmpty()) {
|
||||||
Iterator<WeakReference> iter = cachedFiles.values().iterator();
|
Iterator<WeakReference<MacOSXPreferencesFile>> iter =
|
||||||
|
cachedFiles.values().iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
WeakReference ref = iter.next();
|
WeakReference<MacOSXPreferencesFile> ref = iter.next();
|
||||||
MacOSXPreferencesFile f = (MacOSXPreferencesFile)ref.get();
|
MacOSXPreferencesFile f = ref.get();
|
||||||
if (f != null && f.user == cfCurrentUser) {
|
if (f != null && f.user == cfCurrentUser) {
|
||||||
if (!f.synchronize()) {
|
if (!f.synchronize()) {
|
||||||
ok = false;
|
ok = false;
|
||||||
@ -240,12 +244,10 @@ class MacOSXPreferencesFile {
|
|||||||
boolean ok = true;
|
boolean ok = true;
|
||||||
|
|
||||||
if (changedFiles != null && !changedFiles.isEmpty()) {
|
if (changedFiles != null && !changedFiles.isEmpty()) {
|
||||||
Iterator iter = changedFiles.iterator();
|
for (MacOSXPreferencesFile f : changedFiles) {
|
||||||
while (iter.hasNext()) {
|
if (!f.synchronize())
|
||||||
MacOSXPreferencesFile f = (MacOSXPreferencesFile)iter.next();
|
ok = false;
|
||||||
if (!f.synchronize()) ok = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
changedFiles.clear();
|
changedFiles.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -263,7 +265,8 @@ class MacOSXPreferencesFile {
|
|||||||
private void markChanged()
|
private void markChanged()
|
||||||
{
|
{
|
||||||
// Add this file to the changed file list
|
// Add this file to the changed file list
|
||||||
if (changedFiles == null) changedFiles = new HashSet();
|
if (changedFiles == null)
|
||||||
|
changedFiles = new HashSet<>();
|
||||||
changedFiles.add(this);
|
changedFiles.add(this);
|
||||||
|
|
||||||
// Schedule a new flush and a shutdown hook, if necessary
|
// Schedule a new flush and a shutdown hook, if necessary
|
||||||
@ -309,7 +312,9 @@ class MacOSXPreferencesFile {
|
|||||||
|
|
||||||
if (syncInterval > 0) {
|
if (syncInterval > 0) {
|
||||||
timer().schedule(new TimerTask() {
|
timer().schedule(new TimerTask() {
|
||||||
public void run() { MacOSXPreferencesFile.syncWorld();}
|
@Override
|
||||||
|
public void run() {
|
||||||
|
MacOSXPreferencesFile.syncWorld();}
|
||||||
}, syncInterval * 1000, syncInterval * 1000);
|
}, syncInterval * 1000, syncInterval * 1000);
|
||||||
} else {
|
} else {
|
||||||
// syncInterval property not set. No sync timer ever.
|
// syncInterval property not set. No sync timer ever.
|
||||||
@ -323,6 +328,7 @@ class MacOSXPreferencesFile {
|
|||||||
if (timer == null) {
|
if (timer == null) {
|
||||||
timer = new Timer(true); // daemon
|
timer = new Timer(true); // daemon
|
||||||
Thread flushThread = new Thread() {
|
Thread flushThread = new Thread() {
|
||||||
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
flushWorld();
|
flushWorld();
|
||||||
}
|
}
|
||||||
|
@ -40,7 +40,7 @@ public class CGraphicsDevice extends GraphicsDevice {
|
|||||||
private final int displayID;
|
private final int displayID;
|
||||||
|
|
||||||
// Array of all GraphicsConfig instances for this device
|
// Array of all GraphicsConfig instances for this device
|
||||||
private final CGraphicsConfig[] configs;
|
private final GraphicsConfiguration[] configs;
|
||||||
|
|
||||||
// Default config (temporarily hard coded)
|
// Default config (temporarily hard coded)
|
||||||
private final int DEFAULT_CONFIG = 0;
|
private final int DEFAULT_CONFIG = 0;
|
||||||
@ -49,7 +49,7 @@ public class CGraphicsDevice extends GraphicsDevice {
|
|||||||
|
|
||||||
public CGraphicsDevice(int displayID) {
|
public CGraphicsDevice(int displayID) {
|
||||||
this.displayID = displayID;
|
this.displayID = displayID;
|
||||||
configs = new CGraphicsConfig[] {
|
configs = new GraphicsConfiguration[] {
|
||||||
CGLGraphicsConfig.getConfig(this, 0)
|
CGLGraphicsConfig.getConfig(this, 0)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -66,7 +66,7 @@ public class CGraphicsDevice extends GraphicsDevice {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public GraphicsConfiguration[] getConfigurations() {
|
public GraphicsConfiguration[] getConfigurations() {
|
||||||
return configs;
|
return configs.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,6 +56,8 @@ import sun.java2d.SunGraphics2D;
|
|||||||
import sun.java2d.opengl.OGLRenderQueue;
|
import sun.java2d.opengl.OGLRenderQueue;
|
||||||
import sun.java2d.pipe.Region;
|
import sun.java2d.pipe.Region;
|
||||||
|
|
||||||
|
import sun.util.logging.PlatformLogger;
|
||||||
|
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
import javax.swing.SwingUtilities;
|
import javax.swing.SwingUtilities;
|
||||||
import javax.swing.RepaintManager;
|
import javax.swing.RepaintManager;
|
||||||
@ -65,7 +67,10 @@ import sun.lwawt.macosx.CDropTarget;
|
|||||||
import com.sun.java.swing.SwingUtilities3;
|
import com.sun.java.swing.SwingUtilities3;
|
||||||
|
|
||||||
public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
||||||
implements ComponentPeer, DropTargetPeer {
|
implements ComponentPeer, DropTargetPeer
|
||||||
|
{
|
||||||
|
private static final PlatformLogger focusLog = PlatformLogger.getLogger("sun.lwawt.focus.LWComponentPeer");
|
||||||
|
|
||||||
// State lock is to be used for modifications to this
|
// State lock is to be used for modifications to this
|
||||||
// peer's fields (e.g. bounds, background, font, etc.)
|
// peer's fields (e.g. bounds, background, font, etc.)
|
||||||
// It should be the last lock in the lock chain
|
// It should be the last lock in the lock chain
|
||||||
@ -372,7 +377,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void dispose() {
|
public final void dispose() {
|
||||||
if (disposed.compareAndSet(false, true)) {
|
if (disposed.compareAndSet(false, true)) {
|
||||||
disposeImpl();
|
disposeImpl();
|
||||||
}
|
}
|
||||||
@ -885,7 +890,13 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
|||||||
@Override
|
@Override
|
||||||
public boolean requestFocus(Component lightweightChild, boolean temporary,
|
public boolean requestFocus(Component lightweightChild, boolean temporary,
|
||||||
boolean focusedWindowChangeAllowed, long time,
|
boolean focusedWindowChangeAllowed, long time,
|
||||||
CausedFocusEvent.Cause cause) {
|
CausedFocusEvent.Cause cause)
|
||||||
|
{
|
||||||
|
if (focusLog.isLoggable(PlatformLogger.FINEST)) {
|
||||||
|
focusLog.finest("lightweightChild=" + lightweightChild + ", temporary=" + temporary +
|
||||||
|
", focusedWindowChangeAllowed=" + focusedWindowChangeAllowed +
|
||||||
|
", time= " + time + ", cause=" + cause);
|
||||||
|
}
|
||||||
if (LWKeyboardFocusManagerPeer.getInstance(getAppContext()).
|
if (LWKeyboardFocusManagerPeer.getInstance(getAppContext()).
|
||||||
processSynchronousLightweightTransfer(getTarget(), lightweightChild, temporary,
|
processSynchronousLightweightTransfer(getTarget(), lightweightChild, temporary,
|
||||||
focusedWindowChangeAllowed, time)) {
|
focusedWindowChangeAllowed, time)) {
|
||||||
@ -901,19 +912,44 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
|||||||
case LWKeyboardFocusManagerPeer.SNFH_SUCCESS_PROCEED:
|
case LWKeyboardFocusManagerPeer.SNFH_SUCCESS_PROCEED:
|
||||||
Window parentWindow = SunToolkit.getContainingWindow(getTarget());
|
Window parentWindow = SunToolkit.getContainingWindow(getTarget());
|
||||||
if (parentWindow == null) {
|
if (parentWindow == null) {
|
||||||
|
focusLog.fine("request rejected, parentWindow is null");
|
||||||
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
LWWindowPeer parentPeer = (LWWindowPeer) parentWindow.getPeer();
|
LWWindowPeer parentPeer = (LWWindowPeer) parentWindow.getPeer();
|
||||||
if (parentPeer == null) {
|
if (parentPeer == null) {
|
||||||
|
focusLog.fine("request rejected, parentPeer is null");
|
||||||
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// A fix for 7145768. Ensure the parent window is currently natively focused.
|
||||||
|
// The more evident place to perform this check is in KFM.shouldNativelyFocusHeavyweight,
|
||||||
|
// however that is the shared code and this particular problem's reproducibility has
|
||||||
|
// platform specifics. So, it was decided to narrow down the fix to lwawt (OSX) in
|
||||||
|
// current release. TODO: consider fixing it in the shared code.
|
||||||
|
if (!focusedWindowChangeAllowed) {
|
||||||
|
LWWindowPeer decoratedPeer = parentPeer.isSimpleWindow() ?
|
||||||
|
LWWindowPeer.getOwnerFrameDialog(parentPeer) : parentPeer;
|
||||||
|
|
||||||
|
if (decoratedPeer == null || !decoratedPeer.getPlatformWindow().isActive()) {
|
||||||
|
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
||||||
|
focusLog.fine("request rejected, focusedWindowChangeAllowed==false, " +
|
||||||
|
"decoratedPeer is inactive: " + decoratedPeer);
|
||||||
|
}
|
||||||
|
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
boolean res = parentPeer.requestWindowFocus(cause);
|
boolean res = parentPeer.requestWindowFocus(cause);
|
||||||
// If parent window can be made focused and has been made focused (synchronously)
|
// If parent window can be made focused and has been made focused (synchronously)
|
||||||
// then we can proceed with children, otherwise we retreat
|
// then we can proceed with children, otherwise we retreat
|
||||||
if (!res || !parentWindow.isFocused()) {
|
if (!res || !parentWindow.isFocused()) {
|
||||||
|
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
||||||
|
focusLog.fine("request rejected, res= " + res + ", parentWindow.isFocused()=" +
|
||||||
|
parentWindow.isFocused());
|
||||||
|
}
|
||||||
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -940,8 +976,8 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Image createImage(int w, int h) {
|
public Image createImage(int w, int h) {
|
||||||
// TODO: accelerated image
|
CGraphicsConfig gc = (CGraphicsConfig)getGraphicsConfiguration();
|
||||||
return getGraphicsConfiguration().createCompatibleImage(w, h);
|
return gc.createAcceleratedImage(getTarget(), w, h);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -88,20 +88,20 @@ public abstract class LWCursorManager {
|
|||||||
} else {
|
} else {
|
||||||
cursor = (c != null) ? c.getCursor() : null;
|
cursor = (c != null) ? c.getCursor() : null;
|
||||||
}
|
}
|
||||||
// TODO: default cursor for modal blocked windows
|
|
||||||
setCursor(cursor);
|
setCursor(cursor);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the first visible, enabled and showing component under cursor.
|
* Returns the first visible, enabled and showing component under cursor.
|
||||||
|
* Returns null for modal blocked windows.
|
||||||
*
|
*
|
||||||
* @param cursorPos Current cursor position.
|
* @param cursorPos Current cursor position.
|
||||||
* @return Component
|
* @return Component or null.
|
||||||
*/
|
*/
|
||||||
private static final Component findComponent(final Point cursorPos) {
|
private static final Component findComponent(final Point cursorPos) {
|
||||||
final LWComponentPeer<?, ?> peer = LWWindowPeer.getPeerUnderCursor();
|
final LWComponentPeer<?, ?> peer = LWWindowPeer.getPeerUnderCursor();
|
||||||
Component c = null;
|
Component c = null;
|
||||||
if (peer != null) {
|
if (peer != null && peer.getWindowPeerOrSelf().getBlocker() == null) {
|
||||||
c = peer.getTarget();
|
c = peer.getTarget();
|
||||||
if (c instanceof Container) {
|
if (c instanceof Container) {
|
||||||
final Point p = peer.getLocationOnScreen();
|
final Point p = peer.getLocationOnScreen();
|
||||||
|
@ -81,6 +81,18 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
|
|||||||
firstChangeSkipped = true;
|
firstChangeSkipped = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected final void disposeImpl() {
|
||||||
|
synchronized (getDelegateLock()) {
|
||||||
|
// visible caret has a timer thread which must be stopped
|
||||||
|
getTextComponent().getCaret().setVisible(false);
|
||||||
|
}
|
||||||
|
super.disposeImpl();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method should be called under getDelegateLock().
|
||||||
|
*/
|
||||||
abstract JTextComponent getTextComponent();
|
abstract JTextComponent getTextComponent();
|
||||||
|
|
||||||
public Dimension getPreferredSize(final int rows, final int columns) {
|
public Dimension getPreferredSize(final int rows, final int columns) {
|
||||||
|
@ -50,7 +50,7 @@ public class LWWindowPeer
|
|||||||
EMBEDDEDFRAME
|
EMBEDDEDFRAME
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final sun.util.logging.PlatformLogger focusLog = PlatformLogger.getLogger("sun.lwawt.focus.LWWindowPeer");
|
private static final PlatformLogger focusLog = PlatformLogger.getLogger("sun.lwawt.focus.LWWindowPeer");
|
||||||
|
|
||||||
private PlatformWindow platformWindow;
|
private PlatformWindow platformWindow;
|
||||||
|
|
||||||
@ -101,8 +101,6 @@ public class LWWindowPeer
|
|||||||
// events between MOUSE_PRESSED and MOUSE_RELEASED for particular button
|
// events between MOUSE_PRESSED and MOUSE_RELEASED for particular button
|
||||||
private static int mouseClickButtons = 0;
|
private static int mouseClickButtons = 0;
|
||||||
|
|
||||||
private volatile boolean cachedFocusableWindow;
|
|
||||||
|
|
||||||
private volatile boolean isOpaque = true;
|
private volatile boolean isOpaque = true;
|
||||||
|
|
||||||
private static final Font DEFAULT_FONT = new Font("Lucida Grande", Font.PLAIN, 13);
|
private static final Font DEFAULT_FONT = new Font("Lucida Grande", Font.PLAIN, 13);
|
||||||
@ -172,8 +170,6 @@ public class LWWindowPeer
|
|||||||
setAlwaysOnTop(getTarget().isAlwaysOnTop());
|
setAlwaysOnTop(getTarget().isAlwaysOnTop());
|
||||||
updateMinimumSize();
|
updateMinimumSize();
|
||||||
|
|
||||||
cachedFocusableWindow = getTarget().isFocusableWindow();
|
|
||||||
|
|
||||||
setOpacity(getTarget().getOpacity());
|
setOpacity(getTarget().getOpacity());
|
||||||
setOpaque(getTarget().isOpaque());
|
setOpaque(getTarget().isOpaque());
|
||||||
|
|
||||||
@ -245,15 +241,17 @@ public class LWWindowPeer
|
|||||||
getInstance(getAppContext());
|
getInstance(getAppContext());
|
||||||
|
|
||||||
if (visible) {
|
if (visible) {
|
||||||
updateFocusableWindowState();
|
if (!getTarget().isAutoRequestFocus()) {
|
||||||
changeFocusedWindow(true, true);
|
return;
|
||||||
|
} else {
|
||||||
|
requestWindowFocus(CausedFocusEvent.Cause.ACTIVATION);
|
||||||
|
}
|
||||||
// Focus the owner in case this window is focused.
|
// Focus the owner in case this window is focused.
|
||||||
} else if (manager.getCurrentFocusedWindow() == getTarget()) {
|
} else if (manager.getCurrentFocusedWindow() == getTarget()) {
|
||||||
|
// Transfer focus to the owner.
|
||||||
LWWindowPeer owner = getOwnerFrameDialog(LWWindowPeer.this);
|
LWWindowPeer owner = getOwnerFrameDialog(LWWindowPeer.this);
|
||||||
if (owner != null) {
|
if (owner != null) {
|
||||||
// KFM will do all the rest.
|
owner.requestWindowFocus(CausedFocusEvent.Cause.ACTIVATION);
|
||||||
owner.changeFocusedWindow(true, false);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -400,7 +398,6 @@ public class LWWindowPeer
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateFocusableWindowState() {
|
public void updateFocusableWindowState() {
|
||||||
cachedFocusableWindow = getTarget().isFocusableWindow();
|
|
||||||
platformWindow.updateFocusableWindowState();
|
platformWindow.updateFocusableWindowState();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -409,6 +406,8 @@ public class LWWindowPeer
|
|||||||
synchronized (getPeerTreeLock()) {
|
synchronized (getPeerTreeLock()) {
|
||||||
this.blocker = blocked ? (LWWindowPeer)blocker.getPeer() : null;
|
this.blocker = blocked ? (LWWindowPeer)blocker.getPeer() : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
platformWindow.setModalBlocked(blocked);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -617,7 +616,7 @@ public class LWWindowPeer
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void notifyActivation(boolean activation) {
|
public void notifyActivation(boolean activation) {
|
||||||
changeFocusedWindow(activation, false);
|
changeFocusedWindow(activation);
|
||||||
}
|
}
|
||||||
|
|
||||||
// MouseDown in non-client area
|
// MouseDown in non-client area
|
||||||
@ -1063,6 +1062,10 @@ public class LWWindowPeer
|
|||||||
return lastMouseEventPeer;
|
return lastMouseEventPeer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Requests platform to set native focus on a frame/dialog.
|
||||||
|
* In case of a simple window, triggers appropriate java focus change.
|
||||||
|
*/
|
||||||
public boolean requestWindowFocus(CausedFocusEvent.Cause cause) {
|
public boolean requestWindowFocus(CausedFocusEvent.Cause cause) {
|
||||||
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
||||||
focusLog.fine("requesting native focus to " + this);
|
focusLog.fine("requesting native focus to " + this);
|
||||||
@ -1106,14 +1109,14 @@ public class LWWindowPeer
|
|||||||
}
|
}
|
||||||
|
|
||||||
// DKFM will synthesize all the focus/activation events correctly.
|
// DKFM will synthesize all the focus/activation events correctly.
|
||||||
changeFocusedWindow(true, false);
|
changeFocusedWindow(true);
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// In case the toplevel is active but not focused, change focus directly,
|
// In case the toplevel is active but not focused, change focus directly,
|
||||||
// as requesting native focus on it will not have effect.
|
// as requesting native focus on it will not have effect.
|
||||||
} else if (getTarget() == currentActive && !getTarget().hasFocus()) {
|
} else if (getTarget() == currentActive && !getTarget().hasFocus()) {
|
||||||
|
|
||||||
changeFocusedWindow(true, false);
|
changeFocusedWindow(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return platformWindow.requestWindowFocus();
|
return platformWindow.requestWindowFocus();
|
||||||
@ -1122,7 +1125,19 @@ public class LWWindowPeer
|
|||||||
private boolean focusAllowedFor() {
|
private boolean focusAllowedFor() {
|
||||||
Window window = getTarget();
|
Window window = getTarget();
|
||||||
// TODO: check if modal blocked
|
// TODO: check if modal blocked
|
||||||
return window.isVisible() && window.isEnabled() && window.isFocusableWindow();
|
return window.isVisible() && window.isEnabled() && isFocusableWindow();
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isFocusableWindow() {
|
||||||
|
boolean focusable = getTarget().isFocusableWindow();
|
||||||
|
if (isSimpleWindow()) {
|
||||||
|
LWWindowPeer ownerPeer = getOwnerFrameDialog(this);
|
||||||
|
if (ownerPeer == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return focusable && ownerPeer.getTarget().isFocusableWindow();
|
||||||
|
}
|
||||||
|
return focusable;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isSimpleWindow() {
|
public boolean isSimpleWindow() {
|
||||||
@ -1131,19 +1146,19 @@ public class LWWindowPeer
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* "Delegates" the responsibility of managing focus to keyboard focus manager.
|
* Changes focused window on java level.
|
||||||
*/
|
*/
|
||||||
private void changeFocusedWindow(boolean becomesFocused, boolean isShowing) {
|
private void changeFocusedWindow(boolean becomesFocused) {
|
||||||
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
if (focusLog.isLoggable(PlatformLogger.FINE)) {
|
||||||
focusLog.fine((becomesFocused?"gaining":"loosing") + " focus window: " + this);
|
focusLog.fine((becomesFocused?"gaining":"loosing") + " focus window: " + this);
|
||||||
}
|
}
|
||||||
if (isShowing && !getTarget().isAutoRequestFocus() || skipNextFocusChange) {
|
if (skipNextFocusChange) {
|
||||||
focusLog.fine("skipping focus change");
|
focusLog.fine("skipping focus change");
|
||||||
skipNextFocusChange = false;
|
skipNextFocusChange = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (!isFocusableWindow() && becomesFocused) {
|
||||||
if (!cachedFocusableWindow) {
|
focusLog.fine("the window is not focusable");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (becomesFocused) {
|
if (becomesFocused) {
|
||||||
@ -1182,7 +1197,7 @@ public class LWWindowPeer
|
|||||||
postEvent(windowEvent);
|
postEvent(windowEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static LWWindowPeer getOwnerFrameDialog(LWWindowPeer peer) {
|
static LWWindowPeer getOwnerFrameDialog(LWWindowPeer peer) {
|
||||||
Window owner = (peer != null ? peer.getTarget().getOwner() : null);
|
Window owner = (peer != null ? peer.getTarget().getOwner() : null);
|
||||||
while (owner != null && !(owner instanceof Frame || owner instanceof Dialog)) {
|
while (owner != null && !(owner instanceof Frame || owner instanceof Dialog)) {
|
||||||
owner = owner.getOwner();
|
owner = owner.getOwner();
|
||||||
|
@ -108,6 +108,8 @@ public interface PlatformWindow {
|
|||||||
public void flip(int x1, int y1, int x2, int y2,
|
public void flip(int x1, int y1, int x2, int y2,
|
||||||
BufferCapabilities.FlipContents flipAction);
|
BufferCapabilities.FlipContents flipAction);
|
||||||
|
|
||||||
|
public void setModalBlocked(boolean blocked);
|
||||||
|
|
||||||
public void toFront();
|
public void toFront();
|
||||||
|
|
||||||
public void toBack();
|
public void toBack();
|
||||||
|
@ -112,28 +112,19 @@ public class CEmbeddedFrame extends EmbeddedFrame {
|
|||||||
|
|
||||||
public void handleFocusEvent(boolean focused) {
|
public void handleFocusEvent(boolean focused) {
|
||||||
this.focused = focused;
|
this.focused = focused;
|
||||||
updateOverlayWindowActiveState();
|
if (parentWindowActive) {
|
||||||
|
responder.handleWindowFocusEvent(focused);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleWindowFocusEvent(boolean parentWindowActive) {
|
public void handleWindowFocusEvent(boolean parentWindowActive) {
|
||||||
this.parentWindowActive = parentWindowActive;
|
this.parentWindowActive = parentWindowActive;
|
||||||
updateOverlayWindowActiveState();
|
if (focused) {
|
||||||
|
responder.handleWindowFocusEvent(parentWindowActive);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isParentWindowActive() {
|
public boolean isParentWindowActive() {
|
||||||
return parentWindowActive;
|
return parentWindowActive;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* May change appearance of contents of window, and generate a
|
|
||||||
* WINDOW_ACTIVATED event.
|
|
||||||
*/
|
|
||||||
private void updateOverlayWindowActiveState() {
|
|
||||||
final boolean showAsFocused = parentWindowActive && focused;
|
|
||||||
dispatchEvent(
|
|
||||||
new FocusEvent(this, showAsFocused ?
|
|
||||||
FocusEvent.FOCUS_GAINED :
|
|
||||||
FocusEvent.FOCUS_LOST));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,7 @@ import java.util.List;
|
|||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
|
||||||
import sun.awt.CausedFocusEvent.Cause;
|
import sun.awt.CausedFocusEvent.Cause;
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.java2d.pipe.Region;
|
import sun.java2d.pipe.Region;
|
||||||
|
|
||||||
class CFileDialog implements FileDialogPeer {
|
class CFileDialog implements FileDialogPeer {
|
||||||
@ -53,33 +54,40 @@ class CFileDialog implements FileDialogPeer {
|
|||||||
title = " ";
|
title = " ";
|
||||||
}
|
}
|
||||||
|
|
||||||
String userFileName = nativeRunFileDialog(title,
|
String[] userFileNames = nativeRunFileDialog(title,
|
||||||
dialogMode, navigateApps,
|
dialogMode,
|
||||||
|
target.isMultipleMode(),
|
||||||
|
navigateApps,
|
||||||
target.getFilenameFilter() != null,
|
target.getFilenameFilter() != null,
|
||||||
target.getDirectory(),
|
target.getDirectory(),
|
||||||
target.getFile());
|
target.getFile());
|
||||||
|
|
||||||
File file = null;
|
String directory = null;
|
||||||
if (userFileName != null) {
|
String file = null;
|
||||||
// the dialog wasn't cancelled
|
File[] files = null;
|
||||||
file = new File(userFileName);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file != null) {
|
if (userFileNames != null) {
|
||||||
// make sure directory always ends in '/'
|
// the dialog wasn't cancelled
|
||||||
String parent = file.getParent();
|
int filesNumber = userFileNames.length;
|
||||||
if (!parent.endsWith(File.separator)) {
|
files = new File[filesNumber];
|
||||||
parent = parent + File.separator;
|
for (int i = 0; i < filesNumber; i++) {
|
||||||
|
files[i] = new File(userFileNames[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// store results back in component
|
directory = files[0].getParent();
|
||||||
target.setDirectory(parent);
|
// make sure directory always ends in '/'
|
||||||
target.setFile(file.getName());
|
if (!directory.endsWith(File.separator)) {
|
||||||
} else {
|
directory = directory + File.separator;
|
||||||
// setting file name to null is how we tell
|
}
|
||||||
// java client that user hit the cancel button
|
|
||||||
target.setFile(null);
|
file = files[0].getName(); // pick any file
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// store results back in component
|
||||||
|
AWTAccessor.FileDialogAccessor accessor = AWTAccessor.getFileDialogAccessor();
|
||||||
|
accessor.setDirectory(target, directory);
|
||||||
|
accessor.setFile(target, file);
|
||||||
|
accessor.setFiles(target, files);
|
||||||
} finally {
|
} finally {
|
||||||
// Java2 Dialog waits for hide to let show() return
|
// Java2 Dialog waits for hide to let show() return
|
||||||
target.dispose();
|
target.dispose();
|
||||||
@ -133,8 +141,8 @@ class CFileDialog implements FileDialogPeer {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private native String nativeRunFileDialog(String title, int mode,
|
private native String[] nativeRunFileDialog(String title, int mode,
|
||||||
boolean shouldNavigateApps, boolean hasFilenameFilter,
|
boolean multipleMode, boolean shouldNavigateApps, boolean hasFilenameFilter,
|
||||||
String directory, String file);
|
String directory, String file);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -205,4 +205,7 @@ public class CPlatformEmbeddedFrame implements PlatformWindow {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setWindowState(int windowState) {}
|
public void setWindowState(int windowState) {}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setModalBlocked(boolean blocked) {}
|
||||||
}
|
}
|
||||||
|
@ -204,4 +204,8 @@ final class CPlatformResponder {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void handleWindowFocusEvent(boolean gained) {
|
||||||
|
peer.notifyActivation(gained);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -49,9 +49,9 @@ public class CPlatformView extends CFRetainedResource {
|
|||||||
super(0, true);
|
super(0, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void initialize(LWWindowPeer peer) {
|
public void initialize(LWWindowPeer peer, CPlatformResponder responder) {
|
||||||
this.peer = peer;
|
this.peer = peer;
|
||||||
this.responder = new CPlatformResponder(peer, false);
|
this.responder = responder;
|
||||||
|
|
||||||
if (!LWCToolkit.getSunAwtDisableCALayers()) {
|
if (!LWCToolkit.getSunAwtDisableCALayers()) {
|
||||||
this.windowLayer = new CGLLayer(peer);
|
this.windowLayer = new CGLLayer(peer);
|
||||||
|
@ -61,6 +61,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
private static native void nativeSetNSWindowMinimizedIcon(long nsWindowPtr, long nsImage);
|
private static native void nativeSetNSWindowMinimizedIcon(long nsWindowPtr, long nsImage);
|
||||||
private static native void nativeSetNSWindowRepresentedFilename(long nsWindowPtr, String representedFilename);
|
private static native void nativeSetNSWindowRepresentedFilename(long nsWindowPtr, String representedFilename);
|
||||||
private static native void nativeSetNSWindowSecurityWarningPositioning(long nsWindowPtr, double x, double y, float biasX, float biasY);
|
private static native void nativeSetNSWindowSecurityWarningPositioning(long nsWindowPtr, double x, double y, float biasX, float biasY);
|
||||||
|
private static native void nativeSetEnabled(long nsWindowPtr, boolean isEnabled);
|
||||||
private static native void nativeSynthesizeMouseEnteredExitedEvents(long nsWindowPtr);
|
private static native void nativeSynthesizeMouseEnteredExitedEvents(long nsWindowPtr);
|
||||||
|
|
||||||
private static native int nativeGetScreenNSWindowIsOn_AppKitThread(long nsWindowPtr);
|
private static native int nativeGetScreenNSWindowIsOn_AppKitThread(long nsWindowPtr);
|
||||||
@ -207,6 +208,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
private boolean visible = false; // visibility status from native perspective
|
private boolean visible = false; // visibility status from native perspective
|
||||||
private boolean undecorated; // initialized in getInitialStyleBits()
|
private boolean undecorated; // initialized in getInitialStyleBits()
|
||||||
private Rectangle normalBounds = null; // not-null only for undecorated maximized windows
|
private Rectangle normalBounds = null; // not-null only for undecorated maximized windows
|
||||||
|
private CPlatformResponder responder;
|
||||||
|
|
||||||
public CPlatformWindow(final PeerType peerType) {
|
public CPlatformWindow(final PeerType peerType) {
|
||||||
super(0, true);
|
super(0, true);
|
||||||
@ -231,8 +233,9 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
final long parentNSWindowPtr = (owner != null ? owner.getNSWindowPtr() : 0);
|
final long parentNSWindowPtr = (owner != null ? owner.getNSWindowPtr() : 0);
|
||||||
String warningString = target.getWarningString();
|
String warningString = target.getWarningString();
|
||||||
|
|
||||||
|
responder = new CPlatformResponder(peer, false);
|
||||||
contentView = new CPlatformView();
|
contentView = new CPlatformView();
|
||||||
contentView.initialize(peer);
|
contentView.initialize(peer, responder);
|
||||||
|
|
||||||
final long nativeWindowPtr = nativeCreateNSWindow(contentView.getAWTView(), styleBits, 0, 0, 0, 0);
|
final long nativeWindowPtr = nativeCreateNSWindow(contentView.getAWTView(), styleBits, 0, 0, 0, 0);
|
||||||
setPtr(nativeWindowPtr);
|
setPtr(nativeWindowPtr);
|
||||||
@ -311,6 +314,10 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
styleBits = SET(styleBits, NONACTIVATING, true);
|
styleBits = SET(styleBits, NONACTIVATING, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Window.Type.UTILITY.equals(target.getType())) {
|
||||||
|
styleBits = SET(styleBits, UTILITY, true);
|
||||||
|
}
|
||||||
|
|
||||||
if (target instanceof javax.swing.RootPaneContainer) {
|
if (target instanceof javax.swing.RootPaneContainer) {
|
||||||
javax.swing.JRootPane rootpane = ((javax.swing.RootPaneContainer)target).getRootPane();
|
javax.swing.JRootPane rootpane = ((javax.swing.RootPaneContainer)target).getRootPane();
|
||||||
Object prop = null;
|
Object prop = null;
|
||||||
@ -800,6 +807,15 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
// value when the native notification comes to us
|
// value when the native notification comes to us
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setModalBlocked(boolean blocked) {
|
||||||
|
if (target.getModalExclusionType() == Dialog.ModalExclusionType.APPLICATION_EXCLUDE) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
nativeSetEnabled(getNSWindowPtr(), !blocked);
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
// UTILITY METHODS
|
// UTILITY METHODS
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
@ -851,7 +867,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
focusLogger.fine("the app is inactive, so the notification is ignored");
|
focusLogger.fine("the app is inactive, so the notification is ignored");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
peer.notifyActivation(gained);
|
responder.handleWindowFocusEvent(gained);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void deliverMoveResizeEvent(int x, int y, int width, int height) {
|
private void deliverMoveResizeEvent(int x, int y, int width, int height) {
|
||||||
|
@ -27,9 +27,9 @@ package sun.lwawt.macosx;
|
|||||||
|
|
||||||
import sun.awt.datatransfer.ToolkitThreadBlockedHandler;
|
import sun.awt.datatransfer.ToolkitThreadBlockedHandler;
|
||||||
|
|
||||||
// TODO:BG this class is really a NOOP right now, but should be filled in if needed.
|
|
||||||
|
|
||||||
final class CToolkitThreadBlockedHandler implements ToolkitThreadBlockedHandler {
|
final class CToolkitThreadBlockedHandler implements ToolkitThreadBlockedHandler {
|
||||||
|
private final LWCToolkit toolkit = (LWCToolkit)java.awt.Toolkit.getDefaultToolkit();
|
||||||
|
|
||||||
public void lock() {
|
public void lock() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -41,9 +41,10 @@ final class CToolkitThreadBlockedHandler implements ToolkitThreadBlockedHandler
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void enter() {
|
public void enter() {
|
||||||
|
toolkit.startNativeNestedEventLoop();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void exit() {
|
public void exit() {
|
||||||
|
toolkit.stopNativeNestedEventLoop();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -63,6 +63,10 @@ public class LWCToolkit extends LWToolkit {
|
|||||||
|
|
||||||
private static native void initIDs();
|
private static native void initIDs();
|
||||||
|
|
||||||
|
static native void startNativeNestedEventLoop();
|
||||||
|
|
||||||
|
static native void stopNativeNestedEventLoop();
|
||||||
|
|
||||||
private static CInputMethodDescriptor sInputMethodDescriptor;
|
private static CInputMethodDescriptor sInputMethodDescriptor;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
|
@ -48,7 +48,6 @@
|
|||||||
//#define IM_DEBUG TRUE
|
//#define IM_DEBUG TRUE
|
||||||
//#define EXTRA_DEBUG
|
//#define EXTRA_DEBUG
|
||||||
|
|
||||||
|
|
||||||
static BOOL shouldUsePressAndHold() {
|
static BOOL shouldUsePressAndHold() {
|
||||||
static int shouldUsePressAndHold = -1;
|
static int shouldUsePressAndHold = -1;
|
||||||
if (shouldUsePressAndHold != -1) return shouldUsePressAndHold;
|
if (shouldUsePressAndHold != -1) return shouldUsePressAndHold;
|
||||||
@ -302,6 +301,15 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
-(void) deliverJavaMouseEvent: (NSEvent *) event {
|
-(void) deliverJavaMouseEvent: (NSEvent *) event {
|
||||||
|
BOOL isEnabled = YES;
|
||||||
|
NSWindow* window = [self window];
|
||||||
|
if ([window isKindOfClass: [AWTWindow_Panel class]] || [window isKindOfClass: [AWTWindow_Normal class]]) {
|
||||||
|
isEnabled = [(AWTWindow*)[window delegate] isEnabled];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isEnabled) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
NSEventType type = [event type];
|
NSEventType type = [event type];
|
||||||
|
|
||||||
@ -385,6 +393,14 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
}
|
}
|
||||||
|
|
||||||
-(void) deliverJavaKeyEventHelper: (NSEvent *) event {
|
-(void) deliverJavaKeyEventHelper: (NSEvent *) event {
|
||||||
|
static NSEvent* sLastKeyEvent = nil;
|
||||||
|
if (event == sLastKeyEvent) {
|
||||||
|
// The event is repeatedly delivered by keyDown: after performKeyEquivalent:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
[sLastKeyEvent release];
|
||||||
|
sLastKeyEvent = [event retain];
|
||||||
|
|
||||||
[AWTToolkit eventCountPlusPlus];
|
[AWTToolkit eventCountPlusPlus];
|
||||||
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
||||||
|
|
||||||
|
@ -35,28 +35,53 @@
|
|||||||
|
|
||||||
@class AWTView;
|
@class AWTView;
|
||||||
|
|
||||||
@interface AWTWindow : NSPanel <NSWindowDelegate> {
|
@interface AWTWindow : NSObject <NSWindowDelegate> {
|
||||||
@private
|
@private
|
||||||
JNFWeakJObjectWrapper *javaPlatformWindow;
|
JNFWeakJObjectWrapper *javaPlatformWindow;
|
||||||
CMenuBar *javaMenuBar;
|
CMenuBar *javaMenuBar;
|
||||||
NSSize javaMinSize;
|
NSSize javaMinSize;
|
||||||
NSSize javaMaxSize;
|
NSSize javaMaxSize;
|
||||||
jint styleBits;
|
jint styleBits;
|
||||||
|
BOOL isEnabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// An instance of either AWTWindow_Normal or AWTWindow_Panel
|
||||||
|
@property (nonatomic, retain) NSWindow *nsWindow;
|
||||||
|
|
||||||
@property (nonatomic, retain) JNFWeakJObjectWrapper *javaPlatformWindow;
|
@property (nonatomic, retain) JNFWeakJObjectWrapper *javaPlatformWindow;
|
||||||
@property (nonatomic, retain) CMenuBar *javaMenuBar;
|
@property (nonatomic, retain) CMenuBar *javaMenuBar;
|
||||||
@property (nonatomic) NSSize javaMinSize;
|
@property (nonatomic) NSSize javaMinSize;
|
||||||
@property (nonatomic) NSSize javaMaxSize;
|
@property (nonatomic) NSSize javaMaxSize;
|
||||||
@property (nonatomic) jint styleBits;
|
@property (nonatomic) jint styleBits;
|
||||||
|
@property (nonatomic) BOOL isEnabled;
|
||||||
|
|
||||||
- (id) initWithPlatformWindow:(JNFWeakJObjectWrapper *)javaPlatformWindow
|
- (id) initWithPlatformWindow:(JNFWeakJObjectWrapper *)javaPlatformWindow
|
||||||
styleBits:(jint)styleBits
|
styleBits:(jint)styleBits
|
||||||
frameRect:(NSRect)frameRect
|
frameRect:(NSRect)frameRect
|
||||||
contentView:(NSView *)contentView;
|
contentView:(NSView *)contentView;
|
||||||
|
|
||||||
- (void) adjustGrowBoxWindow;
|
|
||||||
- (BOOL) isTopmostWindowUnderMouse;
|
- (BOOL) isTopmostWindowUnderMouse;
|
||||||
|
|
||||||
|
// NSWindow overrides delegate methods
|
||||||
|
- (BOOL) canBecomeKeyWindow;
|
||||||
|
- (BOOL) canBecomeMainWindow;
|
||||||
|
- (BOOL) worksWhenModal;
|
||||||
|
- (void)sendEvent:(NSEvent *)event;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@interface AWTWindow_Normal : NSWindow
|
||||||
|
- (id) initWithDelegate:(AWTWindow *)delegate
|
||||||
|
frameRect:(NSRect)rect
|
||||||
|
styleMask:(NSUInteger)styleMask
|
||||||
|
contentView:(NSView *)view;
|
||||||
|
@end
|
||||||
|
|
||||||
|
@interface AWTWindow_Panel : NSPanel
|
||||||
|
- (id) initWithDelegate:(AWTWindow *)delegate
|
||||||
|
frameRect:(NSRect)rect
|
||||||
|
styleMask:(NSUInteger)styleMask
|
||||||
|
contentView:(NSView *)view;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
#endif _AWTWINDOW_H
|
#endif _AWTWINDOW_H
|
||||||
|
@ -51,22 +51,76 @@
|
|||||||
|
|
||||||
static JNF_CLASS_CACHE(jc_CPlatformWindow, "sun/lwawt/macosx/CPlatformWindow");
|
static JNF_CLASS_CACHE(jc_CPlatformWindow, "sun/lwawt/macosx/CPlatformWindow");
|
||||||
|
|
||||||
|
// --------------------------------------------------------------
|
||||||
|
// NSWindow/NSPanel descendants implementation
|
||||||
|
#define AWT_NS_WINDOW_IMPLEMENTATION \
|
||||||
|
- (id) initWithDelegate:(AWTWindow *)delegate \
|
||||||
|
frameRect:(NSRect)contectRect \
|
||||||
|
styleMask:(NSUInteger)styleMask \
|
||||||
|
contentView:(NSView *)view \
|
||||||
|
{ \
|
||||||
|
self = [super initWithContentRect:contectRect \
|
||||||
|
styleMask:styleMask \
|
||||||
|
backing:NSBackingStoreBuffered \
|
||||||
|
defer:NO]; \
|
||||||
|
\
|
||||||
|
if (self == nil) return nil; \
|
||||||
|
\
|
||||||
|
[self setDelegate:delegate]; \
|
||||||
|
[self setContentView:view]; \
|
||||||
|
[self setInitialFirstResponder:view]; \
|
||||||
|
[self setReleasedWhenClosed:NO]; \
|
||||||
|
[self setPreservesContentDuringLiveResize:YES]; \
|
||||||
|
\
|
||||||
|
return self; \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
/* NSWindow overrides */ \
|
||||||
|
- (BOOL) canBecomeKeyWindow { \
|
||||||
|
return [(AWTWindow*)[self delegate] canBecomeKeyWindow]; \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
- (BOOL) canBecomeMainWindow { \
|
||||||
|
return [(AWTWindow*)[self delegate] canBecomeMainWindow]; \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
- (BOOL) worksWhenModal { \
|
||||||
|
return [(AWTWindow*)[self delegate] worksWhenModal]; \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
- (void)sendEvent:(NSEvent *)event { \
|
||||||
|
[(AWTWindow*)[self delegate] sendEvent:event]; \
|
||||||
|
[super sendEvent:event]; \
|
||||||
|
}
|
||||||
|
|
||||||
|
@implementation AWTWindow_Normal
|
||||||
|
AWT_NS_WINDOW_IMPLEMENTATION
|
||||||
|
@end
|
||||||
|
@implementation AWTWindow_Panel
|
||||||
|
AWT_NS_WINDOW_IMPLEMENTATION
|
||||||
|
@end
|
||||||
|
// END of NSWindow/NSPanel descendants implementation
|
||||||
|
// --------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
@implementation AWTWindow
|
@implementation AWTWindow
|
||||||
|
|
||||||
|
@synthesize nsWindow;
|
||||||
@synthesize javaPlatformWindow;
|
@synthesize javaPlatformWindow;
|
||||||
@synthesize javaMenuBar;
|
@synthesize javaMenuBar;
|
||||||
@synthesize javaMinSize;
|
@synthesize javaMinSize;
|
||||||
@synthesize javaMaxSize;
|
@synthesize javaMaxSize;
|
||||||
@synthesize styleBits;
|
@synthesize styleBits;
|
||||||
|
@synthesize isEnabled;
|
||||||
|
|
||||||
- (void) updateMinMaxSize:(BOOL)resizable {
|
- (void) updateMinMaxSize:(BOOL)resizable {
|
||||||
if (resizable) {
|
if (resizable) {
|
||||||
[self setMinSize:self.javaMinSize];
|
[self.nsWindow setMinSize:self.javaMinSize];
|
||||||
[self setMaxSize:self.javaMaxSize];
|
[self.nsWindow setMaxSize:self.javaMaxSize];
|
||||||
} else {
|
} else {
|
||||||
NSRect currentFrame = [self frame];
|
NSRect currentFrame = [self.nsWindow frame];
|
||||||
[self setMinSize:currentFrame.size];
|
[self.nsWindow setMinSize:currentFrame.size];
|
||||||
[self setMaxSize:currentFrame.size];
|
[self.nsWindow setMaxSize:currentFrame.size];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,38 +151,38 @@ static JNF_CLASS_CACHE(jc_CPlatformWindow, "sun/lwawt/macosx/CPlatformWindow");
|
|||||||
if (IS(mask, RESIZABLE)) {
|
if (IS(mask, RESIZABLE)) {
|
||||||
BOOL resizable = IS(bits, RESIZABLE);
|
BOOL resizable = IS(bits, RESIZABLE);
|
||||||
[self updateMinMaxSize:resizable];
|
[self updateMinMaxSize:resizable];
|
||||||
[self setShowsResizeIndicator:resizable];
|
[self.nsWindow setShowsResizeIndicator:resizable];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, HAS_SHADOW)) {
|
if (IS(mask, HAS_SHADOW)) {
|
||||||
[self setHasShadow:IS(bits, HAS_SHADOW)];
|
[self.nsWindow setHasShadow:IS(bits, HAS_SHADOW)];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, ZOOMABLE)) {
|
if (IS(mask, ZOOMABLE)) {
|
||||||
[[self standardWindowButton:NSWindowZoomButton] setEnabled:IS(bits, ZOOMABLE)];
|
[[self.nsWindow standardWindowButton:NSWindowZoomButton] setEnabled:IS(bits, ZOOMABLE)];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, ALWAYS_ON_TOP)) {
|
if (IS(mask, ALWAYS_ON_TOP)) {
|
||||||
[self setLevel:IS(bits, ALWAYS_ON_TOP) ? NSFloatingWindowLevel : NSNormalWindowLevel];
|
[self.nsWindow setLevel:IS(bits, ALWAYS_ON_TOP) ? NSFloatingWindowLevel : NSNormalWindowLevel];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, HIDES_ON_DEACTIVATE)) {
|
if (IS(mask, HIDES_ON_DEACTIVATE)) {
|
||||||
[self setHidesOnDeactivate:IS(bits, HIDES_ON_DEACTIVATE)];
|
[self.nsWindow setHidesOnDeactivate:IS(bits, HIDES_ON_DEACTIVATE)];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, DRAGGABLE_BACKGROUND)) {
|
if (IS(mask, DRAGGABLE_BACKGROUND)) {
|
||||||
[self setMovableByWindowBackground:IS(bits, DRAGGABLE_BACKGROUND)];
|
[self.nsWindow setMovableByWindowBackground:IS(bits, DRAGGABLE_BACKGROUND)];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS(mask, DOCUMENT_MODIFIED)) {
|
if (IS(mask, DOCUMENT_MODIFIED)) {
|
||||||
[self setDocumentEdited:IS(bits, DOCUMENT_MODIFIED)];
|
[self.nsWindow setDocumentEdited:IS(bits, DOCUMENT_MODIFIED)];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ([self respondsToSelector:@selector(toggleFullScreen:)]) {
|
if ([self.nsWindow respondsToSelector:@selector(toggleFullScreen:)]) {
|
||||||
if (IS(mask, FULLSCREENABLE)) {
|
if (IS(mask, FULLSCREENABLE)) {
|
||||||
[self setCollectionBehavior:(1 << 7) /*NSWindowCollectionBehaviorFullScreenPrimary*/];
|
[self.nsWindow setCollectionBehavior:(1 << 7) /*NSWindowCollectionBehaviorFullScreenPrimary*/];
|
||||||
} else {
|
} else {
|
||||||
[self setCollectionBehavior:NSWindowCollectionBehaviorDefault];
|
[self.nsWindow setCollectionBehavior:NSWindowCollectionBehaviorDefault];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -150,30 +204,43 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
contentRect.size.height = 1.0;
|
contentRect.size.height = 1.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
self = [super initWithContentRect:contentRect
|
self = [super init];
|
||||||
styleMask:styleMask
|
|
||||||
backing:NSBackingStoreBuffered
|
|
||||||
defer:NO];
|
|
||||||
|
|
||||||
if (self == nil) return nil; // no hope
|
if (self == nil) return nil; // no hope
|
||||||
|
|
||||||
|
if (IS(bits, UTILITY) ||
|
||||||
|
IS(bits, NONACTIVATING) ||
|
||||||
|
IS(bits, HUD) ||
|
||||||
|
IS(bits, HIDES_ON_DEACTIVATE))
|
||||||
|
{
|
||||||
|
self.nsWindow = [[AWTWindow_Panel alloc] initWithDelegate:self
|
||||||
|
frameRect:contentRect
|
||||||
|
styleMask:styleMask
|
||||||
|
contentView:view];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// These windows will appear in the window list in the dock icon menu
|
||||||
|
self.nsWindow = [[AWTWindow_Normal alloc] initWithDelegate:self
|
||||||
|
frameRect:contentRect
|
||||||
|
styleMask:styleMask
|
||||||
|
contentView:view];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (self.nsWindow == nil) return nil; // no hope either
|
||||||
|
|
||||||
|
self.isEnabled = YES;
|
||||||
self.javaPlatformWindow = platformWindow;
|
self.javaPlatformWindow = platformWindow;
|
||||||
self.styleBits = bits;
|
self.styleBits = bits;
|
||||||
[self setPropertiesForStyleBits:styleBits mask:MASK(_METHOD_PROP_BITMASK)];
|
[self setPropertiesForStyleBits:styleBits mask:MASK(_METHOD_PROP_BITMASK)];
|
||||||
|
|
||||||
[self setDelegate:self];
|
|
||||||
[self setContentView:view];
|
|
||||||
[self setInitialFirstResponder:view];
|
|
||||||
[self setReleasedWhenClosed:NO];
|
|
||||||
[self setPreservesContentDuringLiveResize:YES];
|
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
// checks that this window is under the mouse cursor and this point is not overlapped by others windows
|
// checks that this window is under the mouse cursor and this point is not overlapped by others windows
|
||||||
- (BOOL) isTopmostWindowUnderMouse {
|
- (BOOL) isTopmostWindowUnderMouse {
|
||||||
|
|
||||||
int currentWinID = [self windowNumber];
|
int currentWinID = [self.nsWindow windowNumber];
|
||||||
|
|
||||||
NSRect screenRect = [[NSScreen mainScreen] frame];
|
NSRect screenRect = [[NSScreen mainScreen] frame];
|
||||||
NSPoint nsMouseLocation = [NSEvent mouseLocation];
|
NSPoint nsMouseLocation = [NSEvent mouseLocation];
|
||||||
@ -202,7 +269,7 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
|
|
||||||
int eventType = 0;
|
int eventType = 0;
|
||||||
BOOL isUnderMouse = [self isTopmostWindowUnderMouse];
|
BOOL isUnderMouse = [self isTopmostWindowUnderMouse];
|
||||||
BOOL mouseIsOver = [[self contentView] mouseIsOver];
|
BOOL mouseIsOver = [[self.nsWindow contentView] mouseIsOver];
|
||||||
|
|
||||||
if (isUnderMouse && !mouseIsOver) {
|
if (isUnderMouse && !mouseIsOver) {
|
||||||
eventType = NSMouseEntered;
|
eventType = NSMouseEntered;
|
||||||
@ -213,21 +280,21 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
}
|
}
|
||||||
|
|
||||||
NSPoint screenLocation = [NSEvent mouseLocation];
|
NSPoint screenLocation = [NSEvent mouseLocation];
|
||||||
NSPoint windowLocation = [self convertScreenToBase: screenLocation];
|
NSPoint windowLocation = [self.nsWindow convertScreenToBase: screenLocation];
|
||||||
int modifierFlags = (eventType == NSMouseEntered) ? NSMouseEnteredMask : NSMouseExitedMask;
|
int modifierFlags = (eventType == NSMouseEntered) ? NSMouseEnteredMask : NSMouseExitedMask;
|
||||||
|
|
||||||
NSEvent *mouseEvent = [NSEvent enterExitEventWithType: eventType
|
NSEvent *mouseEvent = [NSEvent enterExitEventWithType: eventType
|
||||||
location: windowLocation
|
location: windowLocation
|
||||||
modifierFlags: modifierFlags
|
modifierFlags: modifierFlags
|
||||||
timestamp: 0
|
timestamp: 0
|
||||||
windowNumber: [self windowNumber]
|
windowNumber: [self.nsWindow windowNumber]
|
||||||
context: nil
|
context: nil
|
||||||
eventNumber: 0
|
eventNumber: 0
|
||||||
trackingNumber: 0
|
trackingNumber: 0
|
||||||
userData: nil
|
userData: nil
|
||||||
];
|
];
|
||||||
|
|
||||||
[[self contentView] deliverJavaMouseEvent: mouseEvent];
|
[[self.nsWindow contentView] deliverJavaMouseEvent: mouseEvent];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void) dealloc {
|
- (void) dealloc {
|
||||||
@ -236,19 +303,20 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
||||||
[self.javaPlatformWindow setJObject:nil withEnv:env];
|
[self.javaPlatformWindow setJObject:nil withEnv:env];
|
||||||
|
|
||||||
|
self.nsWindow = nil;
|
||||||
|
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// NSWindow overrides
|
// NSWindow overrides
|
||||||
- (BOOL) canBecomeKeyWindow {
|
- (BOOL) canBecomeKeyWindow {
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
return IS(self.styleBits, SHOULD_BECOME_KEY);
|
return self.isEnabled && IS(self.styleBits, SHOULD_BECOME_KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL) canBecomeMainWindow {
|
- (BOOL) canBecomeMainWindow {
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
return IS(self.styleBits, SHOULD_BECOME_MAIN);
|
return self.isEnabled && IS(self.styleBits, SHOULD_BECOME_MAIN);
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL) worksWhenModal {
|
- (BOOL) worksWhenModal {
|
||||||
@ -270,7 +338,7 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
if (awtWindow != NULL) {
|
if (awtWindow != NULL) {
|
||||||
// translate the point into Java coordinates
|
// translate the point into Java coordinates
|
||||||
NSPoint loc = [event locationInWindow];
|
NSPoint loc = [event locationInWindow];
|
||||||
loc.y = [self frame].size.height - loc.y;
|
loc.y = [self.nsWindow frame].size.height - loc.y;
|
||||||
|
|
||||||
// send up to the GestureHandler to recursively dispatch on the AWT event thread
|
// send up to the GestureHandler to recursively dispatch on the AWT event thread
|
||||||
static JNF_CLASS_CACHE(jc_GestureHandler, "com/apple/eawt/event/GestureHandler");
|
static JNF_CLASS_CACHE(jc_GestureHandler, "com/apple/eawt/event/GestureHandler");
|
||||||
@ -333,7 +401,7 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
// TODO: create generic AWT assert
|
// TODO: create generic AWT assert
|
||||||
}
|
}
|
||||||
|
|
||||||
NSRect frame = ConvertNSScreenRect(env, [self frame]);
|
NSRect frame = ConvertNSScreenRect(env, [self.nsWindow frame]);
|
||||||
|
|
||||||
static JNF_MEMBER_CACHE(jm_deliverMoveResizeEvent, jc_CPlatformWindow, "deliverMoveResizeEvent", "(IIII)V");
|
static JNF_MEMBER_CACHE(jm_deliverMoveResizeEvent, jc_CPlatformWindow, "deliverMoveResizeEvent", "(IIII)V");
|
||||||
JNFCallVoidMethod(env, platformWindow, jm_deliverMoveResizeEvent,
|
JNFCallVoidMethod(env, platformWindow, jm_deliverMoveResizeEvent,
|
||||||
@ -523,8 +591,8 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
if ([event type] == NSLeftMouseDown || [event type] == NSRightMouseDown || [event type] == NSOtherMouseDown) {
|
if ([event type] == NSLeftMouseDown || [event type] == NSRightMouseDown || [event type] == NSOtherMouseDown) {
|
||||||
|
|
||||||
NSPoint p = [NSEvent mouseLocation];
|
NSPoint p = [NSEvent mouseLocation];
|
||||||
NSRect frame = [self frame];
|
NSRect frame = [self.nsWindow frame];
|
||||||
NSRect contentRect = [self contentRectForFrameRect:frame];
|
NSRect contentRect = [self.nsWindow contentRectForFrameRect:frame];
|
||||||
|
|
||||||
// Check if the click happened in the non-client area (title bar)
|
// Check if the click happened in the non-client area (title bar)
|
||||||
if (p.y >= (frame.origin.y + contentRect.size.height)) {
|
if (p.y >= (frame.origin.y + contentRect.size.height)) {
|
||||||
@ -535,15 +603,14 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
JNFCallVoidMethod(env, platformWindow, jm_deliverNCMouseDown);
|
JNFCallVoidMethod(env, platformWindow, jm_deliverNCMouseDown);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
[super sendEvent:event];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)constrainSize:(NSSize*)size {
|
- (void)constrainSize:(NSSize*)size {
|
||||||
float minWidth = 0.f, minHeight = 0.f;
|
float minWidth = 0.f, minHeight = 0.f;
|
||||||
|
|
||||||
if (IS(self.styleBits, DECORATED)) {
|
if (IS(self.styleBits, DECORATED)) {
|
||||||
NSRect frame = [self frame];
|
NSRect frame = [self.nsWindow frame];
|
||||||
NSRect contentRect = [NSWindow contentRectForFrameRect:frame styleMask:[self styleMask]];
|
NSRect contentRect = [NSWindow contentRectForFrameRect:frame styleMask:[self.nsWindow styleMask]];
|
||||||
|
|
||||||
float top = frame.size.height - contentRect.size.height;
|
float top = frame.size.height - contentRect.size.height;
|
||||||
float left = contentRect.origin.x - frame.origin.x;
|
float left = contentRect.origin.x - frame.origin.x;
|
||||||
@ -562,6 +629,27 @@ AWT_ASSERT_APPKIT_THREAD;
|
|||||||
size->height = MAX(size->height, minHeight);
|
size->height = MAX(size->height, minHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void) setEnabled: (BOOL)flag {
|
||||||
|
self.isEnabled = flag;
|
||||||
|
|
||||||
|
if (IS(self.styleBits, CLOSEABLE)) {
|
||||||
|
[[self.nsWindow standardWindowButton:NSWindowCloseButton] setEnabled: flag];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IS(self.styleBits, MINIMIZABLE)) {
|
||||||
|
[[self.nsWindow standardWindowButton:NSWindowMiniaturizeButton] setEnabled: flag];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IS(self.styleBits, ZOOMABLE)) {
|
||||||
|
[[self.nsWindow standardWindowButton:NSWindowZoomButton] setEnabled: flag];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IS(self.styleBits, RESIZABLE)) {
|
||||||
|
[self updateMinMaxSize:flag];
|
||||||
|
[self.nsWindow setShowsResizeIndicator:flag];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@end // AWTWindow
|
@end // AWTWindow
|
||||||
|
|
||||||
|
|
||||||
@ -596,7 +684,7 @@ AWT_ASSERT_NOT_APPKIT_THREAD;
|
|||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
|
|
||||||
return ptr_to_jlong(window);
|
return ptr_to_jlong(window ? window.nsWindow : nil);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -610,17 +698,19 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowSt
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
// scans the bit field, and only updates the values requested by the mask
|
// scans the bit field, and only updates the values requested by the mask
|
||||||
// (this implicity handles the _CALLBACK_PROP_BITMASK case, since those are passive reads)
|
// (this implicity handles the _CALLBACK_PROP_BITMASK case, since those are passive reads)
|
||||||
jint newBits = window.styleBits & ~mask | bits & mask;
|
jint newBits = window.styleBits & ~mask | bits & mask;
|
||||||
|
|
||||||
// resets the NSWindow's style mask if the mask intersects any of those bits
|
// resets the NSWindow's style mask if the mask intersects any of those bits
|
||||||
if (mask & MASK(_STYLE_PROP_BITMASK)) {
|
if (mask & MASK(_STYLE_PROP_BITMASK)) {
|
||||||
[window setStyleMask:[AWTWindow styleMaskForStyleBits:newBits]];
|
[nsWindow setStyleMask:[AWTWindow styleMaskForStyleBits:newBits]];
|
||||||
}
|
}
|
||||||
|
|
||||||
// calls methods on NSWindow to change other properties, based on the mask
|
// calls methods on NSWindow to change other properties, based on the mask
|
||||||
@ -645,12 +735,14 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowMe
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
CMenuBar *menuBar = OBJC(menuBarPtr);
|
CMenuBar *menuBar = OBJC(menuBarPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
if ([window isKeyWindow]) [window.javaMenuBar deactivate];
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
|
if ([nsWindow isKeyWindow]) [window.javaMenuBar deactivate];
|
||||||
window.javaMenuBar = menuBar;
|
window.javaMenuBar = menuBar;
|
||||||
|
|
||||||
// if ([self isKeyWindow]) {
|
// if ([self isKeyWindow]) {
|
||||||
@ -674,15 +766,15 @@ JNIEXPORT jobject JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeGetNSWindo
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
__block NSRect contentRect = NSZeroRect;
|
__block NSRect contentRect = NSZeroRect;
|
||||||
__block NSRect frame = NSZeroRect;
|
__block NSRect frame = NSZeroRect;
|
||||||
|
|
||||||
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
frame = [window frame];
|
frame = [nsWindow frame];
|
||||||
contentRect = [NSWindow contentRectForFrameRect:frame styleMask:[window styleMask]];
|
contentRect = [NSWindow contentRectForFrameRect:frame styleMask:[nsWindow styleMask]];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
jint top = (jint)(frame.size.height - contentRect.size.height);
|
jint top = (jint)(frame.size.height - contentRect.size.height);
|
||||||
@ -712,19 +804,21 @@ AWT_ASSERT_NOT_APPKIT_THREAD;
|
|||||||
NSRect jrect = NSMakeRect(originX, originY, width, height);
|
NSRect jrect = NSMakeRect(originX, originY, width, height);
|
||||||
|
|
||||||
// TODO: not sure we need displayIfNeeded message in our view
|
// TODO: not sure we need displayIfNeeded message in our view
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
NSRect rect = ConvertNSScreenRect(NULL, jrect);
|
NSRect rect = ConvertNSScreenRect(NULL, jrect);
|
||||||
[window constrainSize:&rect.size];
|
[window constrainSize:&rect.size];
|
||||||
|
|
||||||
[window setFrame:rect display:YES];
|
[nsWindow setFrame:rect display:YES];
|
||||||
|
|
||||||
// only start tracking events if pointer is above the toplevel
|
// only start tracking events if pointer is above the toplevel
|
||||||
// TODO: should post an Entered event if YES.
|
// TODO: should post an Entered event if YES.
|
||||||
NSPoint mLocation = [NSEvent mouseLocation];
|
NSPoint mLocation = [NSEvent mouseLocation];
|
||||||
[window setAcceptsMouseMovedEvents:NSPointInRect(mLocation, rect)];
|
[nsWindow setAcceptsMouseMovedEvents:NSPointInRect(mLocation, rect)];
|
||||||
|
|
||||||
// ensure we repaint the whole window after the resize operation
|
// ensure we repaint the whole window after the resize operation
|
||||||
// (this will also re-enable screen updates, which were disabled above)
|
// (this will also re-enable screen updates, which were disabled above)
|
||||||
@ -752,10 +846,12 @@ AWT_ASSERT_NOT_APPKIT_THREAD;
|
|||||||
if (maxW < 1) maxW = 1;
|
if (maxW < 1) maxW = 1;
|
||||||
if (maxH < 1) maxH = 1;
|
if (maxH < 1) maxH = 1;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
NSSize min = { minW, minH };
|
NSSize min = { minW, minH };
|
||||||
NSSize max = { maxW, maxH };
|
NSSize max = { maxW, maxH };
|
||||||
|
|
||||||
@ -781,11 +877,11 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativePushNSWindowT
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
[window orderBack:nil];
|
[nsWindow orderBack:nil];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -802,14 +898,14 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativePushNSWindowT
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
if (![window isKeyWindow]) {
|
if (![nsWindow isKeyWindow]) {
|
||||||
[window makeKeyAndOrderFront:window];
|
[nsWindow makeKeyAndOrderFront:nsWindow];
|
||||||
} else {
|
} else {
|
||||||
[window orderFront:window];
|
[nsWindow orderFront:nsWindow];
|
||||||
}
|
}
|
||||||
}];
|
}];
|
||||||
|
|
||||||
@ -827,8 +923,8 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowTi
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[window performSelectorOnMainThread:@selector(setTitle:)
|
[nsWindow performSelectorOnMainThread:@selector(setTitle:)
|
||||||
withObject:JNFJavaToNSString(env, jtitle)
|
withObject:JNFJavaToNSString(env, jtitle)
|
||||||
waitUntilDone:NO];
|
waitUntilDone:NO];
|
||||||
|
|
||||||
@ -846,11 +942,11 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowAl
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
[window setAlphaValue:alpha];
|
[nsWindow setAlphaValue:alpha];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -867,11 +963,11 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeRevalidateNSW
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
[window invalidateShadow];
|
[nsWindow invalidateShadow];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -890,8 +986,8 @@ JNIEXPORT jint JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeScreenOn_1App
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
NSDictionary *props = [[window screen] deviceDescription];
|
NSDictionary *props = [[nsWindow screen] deviceDescription];
|
||||||
ret = [[props objectForKey:@"NSScreenNumber"] intValue];
|
ret = [[props objectForKey:@"NSScreenNumber"] intValue];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -910,12 +1006,12 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowMi
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
NSImage *image = OBJC(nsImagePtr);
|
NSImage *image = OBJC(nsImagePtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
[window setMiniwindowImage:image];
|
[nsWindow setMiniwindowImage:image];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -932,12 +1028,12 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowRe
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
NSURL *url = (filename == NULL) ? nil : [NSURL fileURLWithPath:JNFNormalizedNSStringForPath(env, filename)];
|
NSURL *url = (filename == NULL) ? nil : [NSURL fileURLWithPath:JNFNormalizedNSStringForPath(env, filename)];
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
[window setRepresentedURL:url];
|
[nsWindow setRepresentedURL:url];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -970,10 +1066,12 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSynthesizeMou
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
[window synthesizeMouseEnteredExitedEvents];
|
[window synthesizeMouseEnteredExitedEvents];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
@ -993,8 +1091,8 @@ JNIEXPORT jint JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeGetScreenNSWi
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
NSScreen* screen = [window screen];
|
NSScreen* screen = [nsWindow screen];
|
||||||
|
|
||||||
//+++gdb NOTE: This is using a linear search of the screens. If it should
|
//+++gdb NOTE: This is using a linear search of the screens. If it should
|
||||||
// prove to be a bottleneck, this can definitely be improved. However,
|
// prove to be a bottleneck, this can definitely be improved. However,
|
||||||
@ -1025,12 +1123,12 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow__1toggleFullScreenM
|
|||||||
{
|
{
|
||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
|
|
||||||
AWTWindow *window = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
SEL toggleFullScreenSelector = @selector(toggleFullScreen:);
|
SEL toggleFullScreenSelector = @selector(toggleFullScreen:);
|
||||||
if (![window respondsToSelector:toggleFullScreenSelector]) return;
|
if (![nsWindow respondsToSelector:toggleFullScreenSelector]) return;
|
||||||
|
|
||||||
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
[window performSelector:toggleFullScreenSelector withObject:nil];
|
[nsWindow performSelector:toggleFullScreenSelector withObject:nil];
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
@ -1044,15 +1142,31 @@ JNIEXPORT jboolean JNICALL Java_sun_lwawt_macosx_CMouseInfoPeer_nativeIsWindowUn
|
|||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
AWT_ASSERT_NOT_APPKIT_THREAD;
|
||||||
|
|
||||||
AWTWindow *aWindow = OBJC(windowPtr);
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^() {
|
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^() {
|
||||||
AWT_ASSERT_APPKIT_THREAD;
|
AWT_ASSERT_APPKIT_THREAD;
|
||||||
|
|
||||||
NSPoint pt = [aWindow mouseLocationOutsideOfEventStream];
|
NSPoint pt = [nsWindow mouseLocationOutsideOfEventStream];
|
||||||
underMouse = [[aWindow contentView] hitTest:pt] != nil;
|
underMouse = [[nsWindow contentView] hitTest:pt] != nil;
|
||||||
}];
|
}];
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
|
|
||||||
return underMouse;
|
return underMouse;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetEnabled
|
||||||
|
(JNIEnv *env, jclass clazz, jlong windowPtr, jboolean isEnabled)
|
||||||
|
{
|
||||||
|
JNF_COCOA_ENTER(env);
|
||||||
|
|
||||||
|
NSWindow *nsWindow = OBJC(windowPtr);
|
||||||
|
[JNFRunLoop performOnMainThreadWaiting:NO withBlock:^(){
|
||||||
|
AWTWindow *window = (AWTWindow*)[nsWindow delegate];
|
||||||
|
|
||||||
|
[window setEnabled: isEnabled];
|
||||||
|
}];
|
||||||
|
|
||||||
|
JNF_COCOA_EXIT(env);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -46,11 +46,14 @@
|
|||||||
// File dialog's mode
|
// File dialog's mode
|
||||||
jint fMode;
|
jint fMode;
|
||||||
|
|
||||||
|
// Indicates whether the user can select multiple files
|
||||||
|
BOOL fMultipleMode;
|
||||||
|
|
||||||
// Should we navigate into apps?
|
// Should we navigate into apps?
|
||||||
BOOL fNavigateApps;
|
BOOL fNavigateApps;
|
||||||
|
|
||||||
// panel's filename
|
// Contains the absolute paths of the selected files as URLs
|
||||||
NSString *fReturnedFilename;
|
NSArray *fURLs;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allocator
|
// Allocator
|
||||||
@ -60,6 +63,7 @@
|
|||||||
directory:(NSString *)inPath
|
directory:(NSString *)inPath
|
||||||
file:(NSString *)inFile
|
file:(NSString *)inFile
|
||||||
mode:(jint)inMode
|
mode:(jint)inMode
|
||||||
|
multipleMode:(BOOL)inMultipleMode
|
||||||
shouldNavigate:(BOOL)inNavigateApps
|
shouldNavigate:(BOOL)inNavigateApps
|
||||||
withEnv:(JNIEnv*)env;
|
withEnv:(JNIEnv*)env;
|
||||||
|
|
||||||
@ -69,7 +73,7 @@
|
|||||||
// Get dialog return value
|
// Get dialog return value
|
||||||
- (BOOL) userClickedOK;
|
- (BOOL) userClickedOK;
|
||||||
|
|
||||||
// Filename user chose
|
// Returns the absolute paths of the selected files as URLs
|
||||||
- (NSString *) filename;
|
- (NSArray *) URLs;
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
directory:(NSString *)inPath
|
directory:(NSString *)inPath
|
||||||
file:(NSString *)inFile
|
file:(NSString *)inFile
|
||||||
mode:(jint)inMode
|
mode:(jint)inMode
|
||||||
|
multipleMode:(BOOL)inMultipleMode
|
||||||
shouldNavigate:(BOOL)inNavigateApps
|
shouldNavigate:(BOOL)inNavigateApps
|
||||||
withEnv:(JNIEnv*)env;
|
withEnv:(JNIEnv*)env;
|
||||||
{
|
{
|
||||||
@ -54,6 +55,7 @@
|
|||||||
fTitle = inTitle;
|
fTitle = inTitle;
|
||||||
[fTitle retain];
|
[fTitle retain];
|
||||||
fMode = inMode;
|
fMode = inMode;
|
||||||
|
fMultipleMode = inMultipleMode;
|
||||||
fNavigateApps = inNavigateApps;
|
fNavigateApps = inNavigateApps;
|
||||||
fPanelResult = NSCancelButton;
|
fPanelResult = NSCancelButton;
|
||||||
}
|
}
|
||||||
@ -79,8 +81,8 @@
|
|||||||
[fTitle release];
|
[fTitle release];
|
||||||
fTitle = nil;
|
fTitle = nil;
|
||||||
|
|
||||||
[fReturnedFilename release];
|
[fURLs release];
|
||||||
fReturnedFilename = nil;
|
fURLs = nil;
|
||||||
|
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
@ -105,7 +107,7 @@
|
|||||||
|
|
||||||
if (fMode == java_awt_FileDialog_LOAD) {
|
if (fMode == java_awt_FileDialog_LOAD) {
|
||||||
NSOpenPanel *openPanel = (NSOpenPanel *)thePanel;
|
NSOpenPanel *openPanel = (NSOpenPanel *)thePanel;
|
||||||
[openPanel setAllowsMultipleSelection:NO];
|
[openPanel setAllowsMultipleSelection:fMultipleMode];
|
||||||
[openPanel setCanChooseFiles:YES];
|
[openPanel setCanChooseFiles:YES];
|
||||||
[openPanel setCanChooseDirectories:NO];
|
[openPanel setCanChooseDirectories:NO];
|
||||||
[openPanel setCanCreateDirectories:YES];
|
[openPanel setCanCreateDirectories:YES];
|
||||||
@ -114,8 +116,16 @@
|
|||||||
[thePanel setDelegate:self];
|
[thePanel setDelegate:self];
|
||||||
fPanelResult = [thePanel runModalForDirectory:fDirectory file:fFile];
|
fPanelResult = [thePanel runModalForDirectory:fDirectory file:fFile];
|
||||||
[thePanel setDelegate:nil];
|
[thePanel setDelegate:nil];
|
||||||
fReturnedFilename = [thePanel filename];
|
|
||||||
[fReturnedFilename retain];
|
if ([self userClickedOK]) {
|
||||||
|
if (fMode == java_awt_FileDialog_LOAD) {
|
||||||
|
NSOpenPanel *openPanel = (NSOpenPanel *)thePanel;
|
||||||
|
fURLs = [openPanel URLs];
|
||||||
|
} else {
|
||||||
|
fURLs = [NSArray arrayWithObject:[thePanel URL]];
|
||||||
|
}
|
||||||
|
[fURLs retain];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[self disposer];
|
[self disposer];
|
||||||
@ -158,8 +168,8 @@
|
|||||||
return fPanelResult == NSOKButton;
|
return fPanelResult == NSOKButton;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (NSString *)filename {
|
- (NSArray *)URLs {
|
||||||
return [[fReturnedFilename retain] autorelease];
|
return [[fURLs retain] autorelease];
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
@ -167,13 +177,14 @@
|
|||||||
* Class: sun_lwawt_macosx_CFileDialog
|
* Class: sun_lwawt_macosx_CFileDialog
|
||||||
* Method: nativeRunFileDialog
|
* Method: nativeRunFileDialog
|
||||||
* Signature: (Ljava/lang/String;ILjava/io/FilenameFilter;
|
* Signature: (Ljava/lang/String;ILjava/io/FilenameFilter;
|
||||||
* Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
|
* Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
||||||
*/
|
*/
|
||||||
JNIEXPORT jstring JNICALL
|
JNIEXPORT jobjectArray JNICALL
|
||||||
Java_sun_lwawt_macosx_CFileDialog_nativeRunFileDialog
|
Java_sun_lwawt_macosx_CFileDialog_nativeRunFileDialog
|
||||||
(JNIEnv *env, jobject peer, jstring title, jint mode, jboolean navigateApps, jboolean hasFilter, jstring directory, jstring file)
|
(JNIEnv *env, jobject peer, jstring title, jint mode, jboolean multipleMode,
|
||||||
|
jboolean navigateApps, jboolean hasFilter, jstring directory, jstring file)
|
||||||
{
|
{
|
||||||
jstring returnValue = NULL;
|
jobjectArray returnValue = NULL;
|
||||||
|
|
||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
NSString *dialogTitle = JNFJavaToNSString(env, title);
|
NSString *dialogTitle = JNFJavaToNSString(env, title);
|
||||||
@ -187,6 +198,7 @@ JNF_COCOA_ENTER(env);
|
|||||||
directory:JNFJavaToNSString(env, directory)
|
directory:JNFJavaToNSString(env, directory)
|
||||||
file:JNFJavaToNSString(env, file)
|
file:JNFJavaToNSString(env, file)
|
||||||
mode:mode
|
mode:mode
|
||||||
|
multipleMode:multipleMode
|
||||||
shouldNavigate:navigateApps
|
shouldNavigate:navigateApps
|
||||||
withEnv:env];
|
withEnv:env];
|
||||||
|
|
||||||
@ -196,8 +208,18 @@ JNF_COCOA_ENTER(env);
|
|||||||
waitUntilDone:YES];
|
waitUntilDone:YES];
|
||||||
|
|
||||||
if ([dialogDelegate userClickedOK]) {
|
if ([dialogDelegate userClickedOK]) {
|
||||||
NSString *filename = [dialogDelegate filename];
|
NSArray *urls = [dialogDelegate URLs];
|
||||||
returnValue = JNFNSToJavaString(env, filename);
|
jsize count = [urls count];
|
||||||
|
|
||||||
|
jclass stringClass = (*env)->FindClass(env, "java/lang/String");
|
||||||
|
returnValue = (*env)->NewObjectArray(env, count, stringClass, NULL);
|
||||||
|
(*env)->DeleteLocalRef(env, stringClass);
|
||||||
|
|
||||||
|
[urls enumerateObjectsUsingBlock:^(id url, NSUInteger index, BOOL *stop) {
|
||||||
|
jstring filename = JNFNormalizedJavaStringForPath(env, [url path]);
|
||||||
|
(*env)->SetObjectArrayElement(env, returnValue, index, filename);
|
||||||
|
(*env)->DeleteLocalRef(env, filename);
|
||||||
|
}];
|
||||||
}
|
}
|
||||||
|
|
||||||
[dialogDelegate release];
|
[dialogDelegate release];
|
||||||
|
@ -163,7 +163,6 @@ AWT_ASSERT_ANY_THREAD;
|
|||||||
if ([reps count]) {
|
if ([reps count]) {
|
||||||
NSImage *nsImage = [[NSImage alloc] initWithSize:NSMakeSize(0, 0)];
|
NSImage *nsImage = [[NSImage alloc] initWithSize:NSMakeSize(0, 0)];
|
||||||
[nsImage addRepresentations: reps];
|
[nsImage addRepresentations: reps];
|
||||||
[reps release];
|
|
||||||
|
|
||||||
if (nsImage != nil) {
|
if (nsImage != nil) {
|
||||||
CFRetain(nsImage); // GC
|
CFRetain(nsImage); // GC
|
||||||
|
@ -42,6 +42,7 @@ jint* gButtonDownMasks;
|
|||||||
@implementation AWTToolkit
|
@implementation AWTToolkit
|
||||||
|
|
||||||
static long eventCount;
|
static long eventCount;
|
||||||
|
static bool shouldKeepRunningNestedLoop = NO;
|
||||||
|
|
||||||
+ (long) getEventCount{
|
+ (long) getEventCount{
|
||||||
return eventCount;
|
return eventCount;
|
||||||
@ -456,3 +457,36 @@ Java_sun_font_FontManager_populateFontFileNameMap
|
|||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: sun_lwawt_macosx_LWCToolkit
|
||||||
|
* Method: startNativeNestedEventLoop
|
||||||
|
* Signature: ()V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_sun_lwawt_macosx_LWCToolkit_startNativeNestedEventLoop
|
||||||
|
(JNIEnv *env, jclass cls)
|
||||||
|
{
|
||||||
|
if(!shouldKeepRunningNestedLoop) {
|
||||||
|
NSRunLoop *theRL = [NSRunLoop currentRunLoop];
|
||||||
|
NSApplication * app = [NSApplication sharedApplication];
|
||||||
|
shouldKeepRunningNestedLoop = YES;
|
||||||
|
while (shouldKeepRunningNestedLoop && [theRL runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]])
|
||||||
|
{
|
||||||
|
NSEvent * event = [app nextEventMatchingMask: 0xFFFFFFFF untilDate:nil inMode:NSDefaultRunLoopMode dequeue:YES];
|
||||||
|
if (event != nil) {
|
||||||
|
[app sendEvent: event];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: sun_lwawt_macosx_LWCToolkit
|
||||||
|
* Method: stopNativeNestedEventLoop
|
||||||
|
* Signature: ()V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_sun_lwawt_macosx_LWCToolkit_stopNativeNestedEventLoop
|
||||||
|
(JNIEnv *env, jclass cls)
|
||||||
|
{
|
||||||
|
shouldKeepRunningNestedLoop = NO;
|
||||||
|
}
|
||||||
|
@ -204,7 +204,8 @@ JNF_COCOA_ENTER(env);
|
|||||||
if (!CGLSD_MakeCurrentToScratch(env, oglc)) {
|
if (!CGLSD_MakeCurrentToScratch(env, oglc)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
} else if ([NSOpenGLContext currentContext] == nil) {
|
// make sure our context is current
|
||||||
|
} else if ([NSOpenGLContext currentContext] != ctxinfo->context) {
|
||||||
[ctxinfo->context makeCurrentContext];
|
[ctxinfo->context makeCurrentContext];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,16 +38,16 @@ import java.security.spec.*;
|
|||||||
* This class constitutes the core of HMAC-<MD> algorithms, where
|
* This class constitutes the core of HMAC-<MD> algorithms, where
|
||||||
* <MD> can be SHA1 or MD5, etc. See RFC 2104 for spec.
|
* <MD> can be SHA1 or MD5, etc. See RFC 2104 for spec.
|
||||||
*
|
*
|
||||||
* It also contains the implementation classes for the SHA-256,
|
* It also contains the implementation classes for SHA-224, SHA-256,
|
||||||
* SHA-384, and SHA-512 HMACs.
|
* SHA-384, and SHA-512 HMACs.
|
||||||
*
|
*
|
||||||
* @author Jan Luehe
|
* @author Jan Luehe
|
||||||
*/
|
*/
|
||||||
final class HmacCore implements Cloneable {
|
abstract class HmacCore extends MacSpi implements Cloneable {
|
||||||
|
|
||||||
private final MessageDigest md;
|
private MessageDigest md;
|
||||||
private final byte[] k_ipad; // inner padding - key XORd with ipad
|
private byte[] k_ipad; // inner padding - key XORd with ipad
|
||||||
private final byte[] k_opad; // outer padding - key XORd with opad
|
private byte[] k_opad; // outer padding - key XORd with opad
|
||||||
private boolean first; // Is this the first data to be processed?
|
private boolean first; // Is this the first data to be processed?
|
||||||
|
|
||||||
private final int blockLen;
|
private final int blockLen;
|
||||||
@ -72,23 +72,12 @@ final class HmacCore implements Cloneable {
|
|||||||
this(MessageDigest.getInstance(digestAlgorithm), bl);
|
this(MessageDigest.getInstance(digestAlgorithm), bl);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor used for cloning.
|
|
||||||
*/
|
|
||||||
private HmacCore(HmacCore other) throws CloneNotSupportedException {
|
|
||||||
this.md = (MessageDigest)other.md.clone();
|
|
||||||
this.blockLen = other.blockLen;
|
|
||||||
this.k_ipad = other.k_ipad.clone();
|
|
||||||
this.k_opad = other.k_opad.clone();
|
|
||||||
this.first = other.first;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the length of the HMAC in bytes.
|
* Returns the length of the HMAC in bytes.
|
||||||
*
|
*
|
||||||
* @return the HMAC length in bytes.
|
* @return the HMAC length in bytes.
|
||||||
*/
|
*/
|
||||||
int getDigestLength() {
|
protected int engineGetMacLength() {
|
||||||
return this.md.getDigestLength();
|
return this.md.getDigestLength();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,9 +92,8 @@ final class HmacCore implements Cloneable {
|
|||||||
* @exception InvalidAlgorithmParameterException if the given algorithm
|
* @exception InvalidAlgorithmParameterException if the given algorithm
|
||||||
* parameters are inappropriate for this MAC.
|
* parameters are inappropriate for this MAC.
|
||||||
*/
|
*/
|
||||||
void init(Key key, AlgorithmParameterSpec params)
|
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
||||||
|
|
||||||
if (params != null) {
|
if (params != null) {
|
||||||
throw new InvalidAlgorithmParameterException
|
throw new InvalidAlgorithmParameterException
|
||||||
("HMAC does not use parameters");
|
("HMAC does not use parameters");
|
||||||
@ -140,7 +128,7 @@ final class HmacCore implements Cloneable {
|
|||||||
Arrays.fill(secret, (byte)0);
|
Arrays.fill(secret, (byte)0);
|
||||||
secret = null;
|
secret = null;
|
||||||
|
|
||||||
reset();
|
engineReset();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -148,7 +136,7 @@ final class HmacCore implements Cloneable {
|
|||||||
*
|
*
|
||||||
* @param input the input byte to be processed.
|
* @param input the input byte to be processed.
|
||||||
*/
|
*/
|
||||||
void update(byte input) {
|
protected void engineUpdate(byte input) {
|
||||||
if (first == true) {
|
if (first == true) {
|
||||||
// compute digest for 1st pass; start with inner pad
|
// compute digest for 1st pass; start with inner pad
|
||||||
md.update(k_ipad);
|
md.update(k_ipad);
|
||||||
@ -167,7 +155,7 @@ final class HmacCore implements Cloneable {
|
|||||||
* @param offset the offset in <code>input</code> where the input starts.
|
* @param offset the offset in <code>input</code> where the input starts.
|
||||||
* @param len the number of bytes to process.
|
* @param len the number of bytes to process.
|
||||||
*/
|
*/
|
||||||
void update(byte input[], int offset, int len) {
|
protected void engineUpdate(byte input[], int offset, int len) {
|
||||||
if (first == true) {
|
if (first == true) {
|
||||||
// compute digest for 1st pass; start with inner pad
|
// compute digest for 1st pass; start with inner pad
|
||||||
md.update(k_ipad);
|
md.update(k_ipad);
|
||||||
@ -178,7 +166,13 @@ final class HmacCore implements Cloneable {
|
|||||||
md.update(input, offset, len);
|
md.update(input, offset, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void update(ByteBuffer input) {
|
/**
|
||||||
|
* Processes the <code>input.remaining()</code> bytes in the ByteBuffer
|
||||||
|
* <code>input</code>.
|
||||||
|
*
|
||||||
|
* @param input the input byte buffer.
|
||||||
|
*/
|
||||||
|
protected void engineUpdate(ByteBuffer input) {
|
||||||
if (first == true) {
|
if (first == true) {
|
||||||
// compute digest for 1st pass; start with inner pad
|
// compute digest for 1st pass; start with inner pad
|
||||||
md.update(k_ipad);
|
md.update(k_ipad);
|
||||||
@ -194,7 +188,7 @@ final class HmacCore implements Cloneable {
|
|||||||
*
|
*
|
||||||
* @return the HMAC result.
|
* @return the HMAC result.
|
||||||
*/
|
*/
|
||||||
byte[] doFinal() {
|
protected byte[] engineDoFinal() {
|
||||||
if (first == true) {
|
if (first == true) {
|
||||||
// compute digest for 1st pass; start with inner pad
|
// compute digest for 1st pass; start with inner pad
|
||||||
md.update(k_ipad);
|
md.update(k_ipad);
|
||||||
@ -223,7 +217,7 @@ final class HmacCore implements Cloneable {
|
|||||||
* Resets the HMAC for further use, maintaining the secret key that the
|
* Resets the HMAC for further use, maintaining the secret key that the
|
||||||
* HMAC was initialized with.
|
* HMAC was initialized with.
|
||||||
*/
|
*/
|
||||||
void reset() {
|
protected void engineReset() {
|
||||||
if (first == false) {
|
if (first == false) {
|
||||||
md.reset();
|
md.reset();
|
||||||
first = true;
|
first = true;
|
||||||
@ -234,115 +228,38 @@ final class HmacCore implements Cloneable {
|
|||||||
* Clones this object.
|
* Clones this object.
|
||||||
*/
|
*/
|
||||||
public Object clone() throws CloneNotSupportedException {
|
public Object clone() throws CloneNotSupportedException {
|
||||||
return new HmacCore(this);
|
HmacCore copy = (HmacCore) super.clone();
|
||||||
|
copy.md = (MessageDigest) md.clone();
|
||||||
|
copy.k_ipad = k_ipad.clone();
|
||||||
|
copy.k_opad = k_opad.clone();
|
||||||
|
return copy;
|
||||||
|
}
|
||||||
|
|
||||||
|
// nested static class for the HmacSHA224 implementation
|
||||||
|
public static final class HmacSHA224 extends HmacCore {
|
||||||
|
public HmacSHA224() throws NoSuchAlgorithmException {
|
||||||
|
super("SHA-224", 64);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// nested static class for the HmacSHA256 implementation
|
// nested static class for the HmacSHA256 implementation
|
||||||
public static final class HmacSHA256 extends MacSpi implements Cloneable {
|
public static final class HmacSHA256 extends HmacCore {
|
||||||
private final HmacCore core;
|
|
||||||
public HmacSHA256() throws NoSuchAlgorithmException {
|
public HmacSHA256() throws NoSuchAlgorithmException {
|
||||||
core = new HmacCore("SHA-256", 64);
|
super("SHA-256", 64);
|
||||||
}
|
|
||||||
private HmacSHA256(HmacSHA256 base) throws CloneNotSupportedException {
|
|
||||||
core = (HmacCore)base.core.clone();
|
|
||||||
}
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return core.getDigestLength();
|
|
||||||
}
|
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
|
||||||
core.init(key, params);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
core.update(input, offset, len);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return core.doFinal();
|
|
||||||
}
|
|
||||||
protected void engineReset() {
|
|
||||||
core.reset();
|
|
||||||
}
|
|
||||||
public Object clone() throws CloneNotSupportedException {
|
|
||||||
return new HmacSHA256(this);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// nested static class for the HmacSHA384 implementation
|
// nested static class for the HmacSHA384 implementation
|
||||||
public static final class HmacSHA384 extends MacSpi implements Cloneable {
|
public static final class HmacSHA384 extends HmacCore {
|
||||||
private final HmacCore core;
|
|
||||||
public HmacSHA384() throws NoSuchAlgorithmException {
|
public HmacSHA384() throws NoSuchAlgorithmException {
|
||||||
core = new HmacCore("SHA-384", 128);
|
super("SHA-384", 128);
|
||||||
}
|
|
||||||
private HmacSHA384(HmacSHA384 base) throws CloneNotSupportedException {
|
|
||||||
core = (HmacCore)base.core.clone();
|
|
||||||
}
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return core.getDigestLength();
|
|
||||||
}
|
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
|
||||||
core.init(key, params);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
core.update(input, offset, len);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return core.doFinal();
|
|
||||||
}
|
|
||||||
protected void engineReset() {
|
|
||||||
core.reset();
|
|
||||||
}
|
|
||||||
public Object clone() throws CloneNotSupportedException {
|
|
||||||
return new HmacSHA384(this);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// nested static class for the HmacSHA512 implementation
|
// nested static class for the HmacSHA512 implementation
|
||||||
public static final class HmacSHA512 extends MacSpi implements Cloneable {
|
public static final class HmacSHA512 extends HmacCore {
|
||||||
private final HmacCore core;
|
|
||||||
public HmacSHA512() throws NoSuchAlgorithmException {
|
public HmacSHA512() throws NoSuchAlgorithmException {
|
||||||
core = new HmacCore("SHA-512", 128);
|
super("SHA-512", 128);
|
||||||
}
|
|
||||||
private HmacSHA512(HmacSHA512 base) throws CloneNotSupportedException {
|
|
||||||
core = (HmacCore)base.core.clone();
|
|
||||||
}
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return core.getDigestLength();
|
|
||||||
}
|
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
|
||||||
core.init(key, params);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
core.update(input, offset, len);
|
|
||||||
}
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
core.update(input);
|
|
||||||
}
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return core.doFinal();
|
|
||||||
}
|
|
||||||
protected void engineReset() {
|
|
||||||
core.reset();
|
|
||||||
}
|
|
||||||
public Object clone() throws CloneNotSupportedException {
|
|
||||||
return new HmacSHA512(this);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2009, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -37,97 +37,11 @@ import java.security.spec.*;
|
|||||||
*
|
*
|
||||||
* @author Jan Luehe
|
* @author Jan Luehe
|
||||||
*/
|
*/
|
||||||
public final class HmacMD5 extends MacSpi implements Cloneable {
|
public final class HmacMD5 extends HmacCore {
|
||||||
|
|
||||||
private HmacCore hmac;
|
|
||||||
private static final int MD5_BLOCK_LENGTH = 64;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacMD5 instance.
|
* Standard constructor, creates a new HmacMD5 instance.
|
||||||
*/
|
*/
|
||||||
public HmacMD5() throws NoSuchAlgorithmException {
|
public HmacMD5() throws NoSuchAlgorithmException {
|
||||||
hmac = new HmacCore(MessageDigest.getInstance("MD5"),
|
super("MD5", 64);
|
||||||
MD5_BLOCK_LENGTH);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the length of the HMAC in bytes.
|
|
||||||
*
|
|
||||||
* @return the HMAC length in bytes.
|
|
||||||
*/
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return hmac.getDigestLength();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initializes the HMAC with the given secret key and algorithm parameters.
|
|
||||||
*
|
|
||||||
* @param key the secret key.
|
|
||||||
* @param params the algorithm parameters.
|
|
||||||
*
|
|
||||||
* @exception InvalidKeyException if the given key is inappropriate for
|
|
||||||
* initializing this MAC.
|
|
||||||
* @exception InvalidAlgorithmParameterException if the given algorithm
|
|
||||||
* parameters are inappropriate for this MAC.
|
|
||||||
*/
|
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
|
||||||
hmac.init(key, params);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the given byte.
|
|
||||||
*
|
|
||||||
* @param input the input byte to be processed.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the first <code>len</code> bytes in <code>input</code>,
|
|
||||||
* starting at <code>offset</code>.
|
|
||||||
*
|
|
||||||
* @param input the input buffer.
|
|
||||||
* @param offset the offset in <code>input</code> where the input starts.
|
|
||||||
* @param len the number of bytes to process.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
hmac.update(input, offset, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Completes the HMAC computation and resets the HMAC for further use,
|
|
||||||
* maintaining the secret key that the HMAC was initialized with.
|
|
||||||
*
|
|
||||||
* @return the HMAC result.
|
|
||||||
*/
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return hmac.doFinal();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resets the HMAC for further use, maintaining the secret key that the
|
|
||||||
* HMAC was initialized with.
|
|
||||||
*/
|
|
||||||
protected void engineReset() {
|
|
||||||
hmac.reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Clones this object.
|
|
||||||
*/
|
|
||||||
public Object clone() {
|
|
||||||
HmacMD5 that = null;
|
|
||||||
try {
|
|
||||||
that = (HmacMD5) super.clone();
|
|
||||||
that.hmac = (HmacCore) this.hmac.clone();
|
|
||||||
} catch (CloneNotSupportedException e) {
|
|
||||||
}
|
|
||||||
return that;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2009, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,26 +41,13 @@ import java.security.spec.*;
|
|||||||
*
|
*
|
||||||
* @author Valerie Peng
|
* @author Valerie Peng
|
||||||
*/
|
*/
|
||||||
public final class HmacPKCS12PBESHA1 extends MacSpi implements Cloneable {
|
public final class HmacPKCS12PBESHA1 extends HmacCore {
|
||||||
|
|
||||||
private HmacCore hmac = null;
|
|
||||||
private static final int SHA1_BLOCK_LENGTH = 64;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacSHA1 instance.
|
* Standard constructor, creates a new HmacSHA1 instance.
|
||||||
*/
|
*/
|
||||||
public HmacPKCS12PBESHA1() throws NoSuchAlgorithmException {
|
public HmacPKCS12PBESHA1() throws NoSuchAlgorithmException {
|
||||||
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
super("SHA1", 64);
|
||||||
SHA1_BLOCK_LENGTH);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the length of the HMAC in bytes.
|
|
||||||
*
|
|
||||||
* @return the HMAC length in bytes.
|
|
||||||
*/
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return hmac.getDigestLength();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -71,7 +58,7 @@ public final class HmacPKCS12PBESHA1 extends MacSpi implements Cloneable {
|
|||||||
*
|
*
|
||||||
* @exception InvalidKeyException if the given key is inappropriate for
|
* @exception InvalidKeyException if the given key is inappropriate for
|
||||||
* initializing this MAC.
|
* initializing this MAC.
|
||||||
u* @exception InvalidAlgorithmParameterException if the given algorithm
|
* @exception InvalidAlgorithmParameterException if the given algorithm
|
||||||
* parameters are inappropriate for this MAC.
|
* parameters are inappropriate for this MAC.
|
||||||
*/
|
*/
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
||||||
@ -140,64 +127,8 @@ public final class HmacPKCS12PBESHA1 extends MacSpi implements Cloneable {
|
|||||||
("IterationCount must be a positive number");
|
("IterationCount must be a positive number");
|
||||||
}
|
}
|
||||||
byte[] derivedKey = PKCS12PBECipherCore.derive(passwdChars, salt,
|
byte[] derivedKey = PKCS12PBECipherCore.derive(passwdChars, salt,
|
||||||
iCount, hmac.getDigestLength(), PKCS12PBECipherCore.MAC_KEY);
|
iCount, engineGetMacLength(), PKCS12PBECipherCore.MAC_KEY);
|
||||||
SecretKey cipherKey = new SecretKeySpec(derivedKey, "HmacSHA1");
|
SecretKey cipherKey = new SecretKeySpec(derivedKey, "HmacSHA1");
|
||||||
hmac.init(cipherKey, null);
|
super.engineInit(cipherKey, null);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the given byte.
|
|
||||||
*
|
|
||||||
* @param input the input byte to be processed.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the first <code>len</code> bytes in <code>input</code>,
|
|
||||||
* starting at <code>offset</code>.
|
|
||||||
*
|
|
||||||
* @param input the input buffer.
|
|
||||||
* @param offset the offset in <code>input</code> where the input starts.
|
|
||||||
* @param len the number of bytes to process.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
hmac.update(input, offset, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Completes the HMAC computation and resets the HMAC for further use,
|
|
||||||
* maintaining the secret key that the HMAC was initialized with.
|
|
||||||
*
|
|
||||||
* @return the HMAC result.
|
|
||||||
*/
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return hmac.doFinal();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resets the HMAC for further use, maintaining the secret key that the
|
|
||||||
* HMAC was initialized with.
|
|
||||||
*/
|
|
||||||
protected void engineReset() {
|
|
||||||
hmac.reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Clones this object.
|
|
||||||
*/
|
|
||||||
public Object clone() {
|
|
||||||
HmacPKCS12PBESHA1 that = null;
|
|
||||||
try {
|
|
||||||
that = (HmacPKCS12PBESHA1)super.clone();
|
|
||||||
that.hmac = (HmacCore)this.hmac.clone();
|
|
||||||
} catch (CloneNotSupportedException e) {
|
|
||||||
}
|
|
||||||
return that;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2009, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -37,97 +37,11 @@ import java.security.spec.*;
|
|||||||
*
|
*
|
||||||
* @author Jan Luehe
|
* @author Jan Luehe
|
||||||
*/
|
*/
|
||||||
public final class HmacSHA1 extends MacSpi implements Cloneable {
|
public final class HmacSHA1 extends HmacCore {
|
||||||
|
|
||||||
private HmacCore hmac = null;
|
|
||||||
private static final int SHA1_BLOCK_LENGTH = 64;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacSHA1 instance.
|
* Standard constructor, creates a new HmacSHA1 instance.
|
||||||
*/
|
*/
|
||||||
public HmacSHA1() throws NoSuchAlgorithmException {
|
public HmacSHA1() throws NoSuchAlgorithmException {
|
||||||
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
super("SHA1", 64);
|
||||||
SHA1_BLOCK_LENGTH);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the length of the HMAC in bytes.
|
|
||||||
*
|
|
||||||
* @return the HMAC length in bytes.
|
|
||||||
*/
|
|
||||||
protected int engineGetMacLength() {
|
|
||||||
return hmac.getDigestLength();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initializes the HMAC with the given secret key and algorithm parameters.
|
|
||||||
*
|
|
||||||
* @param key the secret key.
|
|
||||||
* @param params the algorithm parameters.
|
|
||||||
*
|
|
||||||
* @exception InvalidKeyException if the given key is inappropriate for
|
|
||||||
* initializing this MAC.
|
|
||||||
* @exception InvalidAlgorithmParameterException if the given algorithm
|
|
||||||
* parameters are inappropriate for this MAC.
|
|
||||||
*/
|
|
||||||
protected void engineInit(Key key, AlgorithmParameterSpec params)
|
|
||||||
throws InvalidKeyException, InvalidAlgorithmParameterException {
|
|
||||||
hmac.init(key, params);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the given byte.
|
|
||||||
*
|
|
||||||
* @param input the input byte to be processed.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processes the first <code>len</code> bytes in <code>input</code>,
|
|
||||||
* starting at <code>offset</code>.
|
|
||||||
*
|
|
||||||
* @param input the input buffer.
|
|
||||||
* @param offset the offset in <code>input</code> where the input starts.
|
|
||||||
* @param len the number of bytes to process.
|
|
||||||
*/
|
|
||||||
protected void engineUpdate(byte input[], int offset, int len) {
|
|
||||||
hmac.update(input, offset, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void engineUpdate(ByteBuffer input) {
|
|
||||||
hmac.update(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Completes the HMAC computation and resets the HMAC for further use,
|
|
||||||
* maintaining the secret key that the HMAC was initialized with.
|
|
||||||
*
|
|
||||||
* @return the HMAC result.
|
|
||||||
*/
|
|
||||||
protected byte[] engineDoFinal() {
|
|
||||||
return hmac.doFinal();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resets the HMAC for further use, maintaining the secret key that the
|
|
||||||
* HMAC was initialized with.
|
|
||||||
*/
|
|
||||||
protected void engineReset() {
|
|
||||||
hmac.reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Clones this object.
|
|
||||||
*/
|
|
||||||
public Object clone() {
|
|
||||||
HmacSHA1 that = null;
|
|
||||||
try {
|
|
||||||
that = (HmacSHA1)super.clone();
|
|
||||||
that.hmac = (HmacCore)this.hmac.clone();
|
|
||||||
} catch (CloneNotSupportedException e) {
|
|
||||||
}
|
|
||||||
return that;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2009, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -105,11 +105,11 @@ final class KeyGeneratorCore {
|
|||||||
return new SecretKeySpec(b, name);
|
return new SecretKeySpec(b, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
// nested static class for the HmacSHA256 key generator
|
// nested static classes for the HmacSHA-2 family of key generator
|
||||||
public static final class HmacSHA256KG extends KeyGeneratorSpi {
|
abstract static class HmacSHA2KG extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public HmacSHA256KG() {
|
protected HmacSHA2KG(String algoName, int len) {
|
||||||
core = new KeyGeneratorCore("HmacSHA256", 256);
|
core = new KeyGeneratorCore(algoName, len);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
core.implInit(random);
|
core.implInit(random);
|
||||||
@ -124,47 +124,26 @@ final class KeyGeneratorCore {
|
|||||||
protected SecretKey engineGenerateKey() {
|
protected SecretKey engineGenerateKey() {
|
||||||
return core.implGenerateKey();
|
return core.implGenerateKey();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// nested static class for the HmacSHA384 key generator
|
public static final class SHA224 extends HmacSHA2KG {
|
||||||
public static final class HmacSHA384KG extends KeyGeneratorSpi {
|
public SHA224() {
|
||||||
private final KeyGeneratorCore core;
|
super("HmacSHA224", 224);
|
||||||
public HmacSHA384KG() {
|
}
|
||||||
core = new KeyGeneratorCore("HmacSHA384", 384);
|
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
public static final class SHA256 extends HmacSHA2KG {
|
||||||
core.implInit(random);
|
public SHA256() {
|
||||||
|
super("HmacSHA256", 256);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
protected void engineInit(AlgorithmParameterSpec params,
|
public static final class SHA384 extends HmacSHA2KG {
|
||||||
SecureRandom random) throws InvalidAlgorithmParameterException {
|
public SHA384() {
|
||||||
core.implInit(params, random);
|
super("HmacSHA384", 384);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
protected void engineInit(int keySize, SecureRandom random) {
|
public static final class SHA512 extends HmacSHA2KG {
|
||||||
core.implInit(keySize, random);
|
public SHA512() {
|
||||||
}
|
super("HmacSHA512", 512);
|
||||||
protected SecretKey engineGenerateKey() {
|
}
|
||||||
return core.implGenerateKey();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// nested static class for the HmacSHA384 key generator
|
|
||||||
public static final class HmacSHA512KG extends KeyGeneratorSpi {
|
|
||||||
private final KeyGeneratorCore core;
|
|
||||||
public HmacSHA512KG() {
|
|
||||||
core = new KeyGeneratorCore("HmacSHA512", 512);
|
|
||||||
}
|
|
||||||
protected void engineInit(SecureRandom random) {
|
|
||||||
core.implInit(random);
|
|
||||||
}
|
|
||||||
protected void engineInit(AlgorithmParameterSpec params,
|
|
||||||
SecureRandom random) throws InvalidAlgorithmParameterException {
|
|
||||||
core.implInit(params, random);
|
|
||||||
}
|
|
||||||
protected void engineInit(int keySize, SecureRandom random) {
|
|
||||||
core.implInit(keySize, random);
|
|
||||||
}
|
|
||||||
protected SecretKey engineGenerateKey() {
|
|
||||||
return core.implGenerateKey();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -108,6 +108,8 @@ public final class OAEPParameters extends AlgorithmParametersSpi {
|
|||||||
private static String convertToStandardName(String internalName) {
|
private static String convertToStandardName(String internalName) {
|
||||||
if (internalName.equals("SHA")) {
|
if (internalName.equals("SHA")) {
|
||||||
return "SHA-1";
|
return "SHA-1";
|
||||||
|
} else if (internalName.equals("SHA224")) {
|
||||||
|
return "SHA-224";
|
||||||
} else if (internalName.equals("SHA256")) {
|
} else if (internalName.equals("SHA256")) {
|
||||||
return "SHA-256";
|
return "SHA-256";
|
||||||
} else if (internalName.equals("SHA384")) {
|
} else if (internalName.equals("SHA384")) {
|
||||||
@ -143,6 +145,8 @@ public final class OAEPParameters extends AlgorithmParametersSpi {
|
|||||||
String mgfDigestName = convertToStandardName(params.getName());
|
String mgfDigestName = convertToStandardName(params.getName());
|
||||||
if (mgfDigestName.equals("SHA-1")) {
|
if (mgfDigestName.equals("SHA-1")) {
|
||||||
mgfSpec = MGF1ParameterSpec.SHA1;
|
mgfSpec = MGF1ParameterSpec.SHA1;
|
||||||
|
} else if (mgfDigestName.equals("SHA-224")) {
|
||||||
|
mgfSpec = MGF1ParameterSpec.SHA224;
|
||||||
} else if (mgfDigestName.equals("SHA-256")) {
|
} else if (mgfDigestName.equals("SHA-256")) {
|
||||||
mgfSpec = MGF1ParameterSpec.SHA256;
|
mgfSpec = MGF1ParameterSpec.SHA256;
|
||||||
} else if (mgfDigestName.equals("SHA-384")) {
|
} else if (mgfDigestName.equals("SHA-384")) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -65,7 +65,7 @@ import java.security.SecureRandom;
|
|||||||
*
|
*
|
||||||
* - Diffie-Hellman Key Agreement
|
* - Diffie-Hellman Key Agreement
|
||||||
*
|
*
|
||||||
* - HMAC-MD5, HMAC-SHA1, HMAC-SHA-256, HMAC-SHA-384, HMAC-SHA-512
|
* - HMAC-MD5, HMAC-SHA1, HMAC-SHA-224, HMAC-SHA-256, HMAC-SHA-384, HMAC-SHA-512
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -113,6 +113,7 @@ public final class SunJCE extends Provider {
|
|||||||
"NOPADDING|PKCS1PADDING|OAEPWITHMD5ANDMGF1PADDING"
|
"NOPADDING|PKCS1PADDING|OAEPWITHMD5ANDMGF1PADDING"
|
||||||
+ "|OAEPWITHSHA1ANDMGF1PADDING"
|
+ "|OAEPWITHSHA1ANDMGF1PADDING"
|
||||||
+ "|OAEPWITHSHA-1ANDMGF1PADDING"
|
+ "|OAEPWITHSHA-1ANDMGF1PADDING"
|
||||||
|
+ "|OAEPWITHSHA-224ANDMGF1PADDING"
|
||||||
+ "|OAEPWITHSHA-256ANDMGF1PADDING"
|
+ "|OAEPWITHSHA-256ANDMGF1PADDING"
|
||||||
+ "|OAEPWITHSHA-384ANDMGF1PADDING"
|
+ "|OAEPWITHSHA-384ANDMGF1PADDING"
|
||||||
+ "|OAEPWITHSHA-512ANDMGF1PADDING");
|
+ "|OAEPWITHSHA-512ANDMGF1PADDING");
|
||||||
@ -221,12 +222,25 @@ public final class SunJCE extends Provider {
|
|||||||
put("KeyGenerator.HmacSHA1",
|
put("KeyGenerator.HmacSHA1",
|
||||||
"com.sun.crypto.provider.HmacSHA1KeyGenerator");
|
"com.sun.crypto.provider.HmacSHA1KeyGenerator");
|
||||||
|
|
||||||
|
put("KeyGenerator.HmacSHA224",
|
||||||
|
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA2KG$SHA224");
|
||||||
|
put("Alg.Alias.KeyGenerator.OID.1.2.840.113549.2.8", "HmacSHA224");
|
||||||
|
put("Alg.Alias.KeyGenerator.1.2.840.113549.2.8", "HmacSHA224");
|
||||||
|
|
||||||
put("KeyGenerator.HmacSHA256",
|
put("KeyGenerator.HmacSHA256",
|
||||||
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA256KG");
|
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA2KG$SHA256");
|
||||||
|
put("Alg.Alias.KeyGenerator.OID.1.2.840.113549.2.9", "HmacSHA256");
|
||||||
|
put("Alg.Alias.KeyGenerator.1.2.840.113549.2.9", "HmacSHA256");
|
||||||
|
|
||||||
put("KeyGenerator.HmacSHA384",
|
put("KeyGenerator.HmacSHA384",
|
||||||
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA384KG");
|
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA2KG$SHA384");
|
||||||
|
put("Alg.Alias.KeyGenerator.OID.1.2.840.113549.2.10", "HmacSHA384");
|
||||||
|
put("Alg.Alias.KeyGenerator.1.2.840.113549.2.10", "HmacSHA384");
|
||||||
|
|
||||||
put("KeyGenerator.HmacSHA512",
|
put("KeyGenerator.HmacSHA512",
|
||||||
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA512KG");
|
"com.sun.crypto.provider.KeyGeneratorCore$HmacSHA2KG$SHA512");
|
||||||
|
put("Alg.Alias.KeyGenerator.OID.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
|
put("Alg.Alias.KeyGenerator.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
|
|
||||||
put("KeyPairGenerator.DiffieHellman",
|
put("KeyPairGenerator.DiffieHellman",
|
||||||
"com.sun.crypto.provider.DHKeyPairGenerator");
|
"com.sun.crypto.provider.DHKeyPairGenerator");
|
||||||
@ -389,12 +403,23 @@ public final class SunJCE extends Provider {
|
|||||||
*/
|
*/
|
||||||
put("Mac.HmacMD5", "com.sun.crypto.provider.HmacMD5");
|
put("Mac.HmacMD5", "com.sun.crypto.provider.HmacMD5");
|
||||||
put("Mac.HmacSHA1", "com.sun.crypto.provider.HmacSHA1");
|
put("Mac.HmacSHA1", "com.sun.crypto.provider.HmacSHA1");
|
||||||
|
put("Mac.HmacSHA224",
|
||||||
|
"com.sun.crypto.provider.HmacCore$HmacSHA224");
|
||||||
|
put("Alg.Alias.Mac.OID.1.2.840.113549.2.8", "HmacSHA224");
|
||||||
|
put("Alg.Alias.Mac.1.2.840.113549.2.8", "HmacSHA224");
|
||||||
put("Mac.HmacSHA256",
|
put("Mac.HmacSHA256",
|
||||||
"com.sun.crypto.provider.HmacCore$HmacSHA256");
|
"com.sun.crypto.provider.HmacCore$HmacSHA256");
|
||||||
|
put("Alg.Alias.Mac.OID.1.2.840.113549.2.9", "HmacSHA256");
|
||||||
|
put("Alg.Alias.Mac.1.2.840.113549.2.9", "HmacSHA256");
|
||||||
put("Mac.HmacSHA384",
|
put("Mac.HmacSHA384",
|
||||||
"com.sun.crypto.provider.HmacCore$HmacSHA384");
|
"com.sun.crypto.provider.HmacCore$HmacSHA384");
|
||||||
|
put("Alg.Alias.Mac.OID.1.2.840.113549.2.10", "HmacSHA384");
|
||||||
|
put("Alg.Alias.Mac.1.2.840.113549.2.10", "HmacSHA384");
|
||||||
put("Mac.HmacSHA512",
|
put("Mac.HmacSHA512",
|
||||||
"com.sun.crypto.provider.HmacCore$HmacSHA512");
|
"com.sun.crypto.provider.HmacCore$HmacSHA512");
|
||||||
|
put("Alg.Alias.Mac.OID.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
|
put("Alg.Alias.Mac.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
|
|
||||||
put("Mac.HmacPBESHA1",
|
put("Mac.HmacPBESHA1",
|
||||||
"com.sun.crypto.provider.HmacPKCS12PBESHA1");
|
"com.sun.crypto.provider.HmacPKCS12PBESHA1");
|
||||||
|
|
||||||
@ -405,6 +430,7 @@ public final class SunJCE extends Provider {
|
|||||||
|
|
||||||
put("Mac.HmacMD5 SupportedKeyFormats", "RAW");
|
put("Mac.HmacMD5 SupportedKeyFormats", "RAW");
|
||||||
put("Mac.HmacSHA1 SupportedKeyFormats", "RAW");
|
put("Mac.HmacSHA1 SupportedKeyFormats", "RAW");
|
||||||
|
put("Mac.HmacSHA224 SupportedKeyFormats", "RAW");
|
||||||
put("Mac.HmacSHA256 SupportedKeyFormats", "RAW");
|
put("Mac.HmacSHA256 SupportedKeyFormats", "RAW");
|
||||||
put("Mac.HmacSHA384 SupportedKeyFormats", "RAW");
|
put("Mac.HmacSHA384 SupportedKeyFormats", "RAW");
|
||||||
put("Mac.HmacSHA512 SupportedKeyFormats", "RAW");
|
put("Mac.HmacSHA512 SupportedKeyFormats", "RAW");
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Cancel
|
FileChooser.cancelButton.textAndMnemonic=Cancel
|
||||||
FileChooser.saveButtonText=Save
|
FileChooser.saveButton.textAndMnemonic=Save
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Save
|
FileChooser.saveDialogTitle.textAndMnemonic=Save
|
||||||
FileChooser.openDialogTitleText=Open
|
FileChooser.openDialogTitle.textAndMnemonic=Open
|
||||||
FileChooser.updateButtonText=Update
|
FileChooser.updateButton.textAndMnemonic=Update
|
||||||
FileChooser.helpButtonText=Help
|
FileChooser.helpButton.textAndMnemonic=Help
|
||||||
FileChooser.pathLabelText=Enter path or folder name:
|
FileChooser.pathLabel.textAndMnemonic=Enter &path or folder name:
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filte&r
|
||||||
FileChooser.filterLabelText=Filter
|
FileChooser.foldersLabel.textAndMnemonic=Fo&lders
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=F&iles
|
||||||
FileChooser.foldersLabelText=Folders
|
FileChooser.enterFileNameLabel.textAndMnemonic=E&nter file name:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Enter folder name:
|
||||||
FileChooser.filesLabelText=Files
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Enter file name:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Enter folder name:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Abort file chooser dialog.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Abort file chooser dialog.
|
||||||
FileChooser.saveButtonToolTipText=Save selected file.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Save selected file.
|
||||||
FileChooser.openButtonToolTipText=Open selected file.
|
FileChooser.openButtonToolTip.textAndMnemonic=Open selected file.
|
||||||
FileChooser.updateButtonToolTipText=Update directory listing.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Update directory listing.
|
||||||
FileChooser.helpButtonToolTipText=FileChooser help.
|
FileChooser.helpButtonToolTip.textAndMnemonic=FileChooser help.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Abbrechen
|
FileChooser.cancelButton.textAndMnemonic=Abbrechen
|
||||||
FileChooser.saveButtonText=Speichern
|
FileChooser.saveButton.textAndMnemonic=Speichern
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Speichern
|
FileChooser.saveDialogTitle.textAndMnemonic=Speichern
|
||||||
FileChooser.openDialogTitleText=\u00D6ffnen
|
FileChooser.openDialogTitle.textAndMnemonic=\u00D6ffnen
|
||||||
FileChooser.updateButtonText=Aktualisieren
|
FileChooser.updateButton.textAndMnemonic=Aktualisieren
|
||||||
FileChooser.helpButtonText=Hilfe
|
FileChooser.helpButton.textAndMnemonic=Hilfe
|
||||||
FileChooser.pathLabelText=Pfad- oder Ordnernamen eingeben:
|
FileChooser.pathLabel.textAndMnemonic=&Pfad- oder Ordnernamen eingeben:
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filte&r
|
||||||
FileChooser.filterLabelText=Filter
|
FileChooser.foldersLabel.textAndMnemonic=Ordner(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=Date&ien
|
||||||
FileChooser.foldersLabelText=Ordner
|
FileChooser.enterFileNameLabel.textAndMnemonic=Datei&namen eingeben:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Ordnernamen eingeben:
|
||||||
FileChooser.filesLabelText=Dateien
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Dateinamen eingeben:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Ordnernamen eingeben:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Dialogfeld f\u00FCr Dateiauswahl schlie\u00DFen.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Dialogfeld f\u00FCr Dateiauswahl schlie\u00DFen.
|
||||||
FileChooser.saveButtonToolTipText=Ausgew\u00E4hlte Datei speichern.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Ausgew\u00E4hlte Datei speichern.
|
||||||
FileChooser.openButtonToolTipText=Ausgew\u00E4hlte Datei \u00F6ffnen.
|
FileChooser.openButtonToolTip.textAndMnemonic=Ausgew\u00E4hlte Datei \u00F6ffnen.
|
||||||
FileChooser.updateButtonToolTipText=Verzeichnisliste aktualisieren.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Verzeichnisliste aktualisieren.
|
||||||
FileChooser.helpButtonToolTipText=FileChooser-Hilfe.
|
FileChooser.helpButtonToolTip.textAndMnemonic=FileChooser-Hilfe.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Cancelar
|
FileChooser.cancelButton.textAndMnemonic=Cancelar
|
||||||
FileChooser.saveButtonText=Guardar
|
FileChooser.saveButton.textAndMnemonic=Guardar
|
||||||
FileChooser.openButtonText=Aceptar
|
FileChooser.openButton.textAndMnemonic=Aceptar
|
||||||
FileChooser.saveDialogTitleText=Guardar
|
FileChooser.saveDialogTitle.textAndMnemonic=Guardar
|
||||||
FileChooser.openDialogTitleText=Abrir
|
FileChooser.openDialogTitle.textAndMnemonic=Abrir
|
||||||
FileChooser.updateButtonText=Actualizar
|
FileChooser.updateButton.textAndMnemonic=Actualizar
|
||||||
FileChooser.helpButtonText=Ayuda
|
FileChooser.helpButton.textAndMnemonic=Ayuda
|
||||||
FileChooser.pathLabelText=Introducir nombre de la ruta de acceso o carpeta:
|
FileChooser.pathLabel.textAndMnemonic=Introducir nombre de la ruta de acceso o car&peta:
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filt&ro
|
||||||
FileChooser.filterLabelText=Filtro
|
FileChooser.foldersLabel.textAndMnemonic=Carpetas(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=Arch&ivos
|
||||||
FileChooser.foldersLabelText=Carpetas
|
FileChooser.enterFileNameLabel.textAndMnemonic=I&ntroducir nombre de archivo:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Introducir nombre de carpeta:
|
||||||
FileChooser.filesLabelText=Archivos
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Introducir nombre de archivo:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Introducir nombre de carpeta:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Abortar cuadro de di\u00E1logo del selector de archivos.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Abortar cuadro de di\u00E1logo del selector de archivos.
|
||||||
FileChooser.saveButtonToolTipText=Guardar archivo seleccionado.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Guardar archivo seleccionado.
|
||||||
FileChooser.openButtonToolTipText=Abrir archivo seleccionado.
|
FileChooser.openButtonToolTip.textAndMnemonic=Abrir archivo seleccionado.
|
||||||
FileChooser.updateButtonToolTipText=Actualizar lista de directorios.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Actualizar lista de directorios.
|
||||||
FileChooser.helpButtonToolTipText=Ayuda del selector de archivos.
|
FileChooser.helpButtonToolTip.textAndMnemonic=Ayuda del selector de archivos.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Annuler
|
FileChooser.cancelButton.textAndMnemonic=Annuler
|
||||||
FileChooser.saveButtonText=Enregistrer
|
FileChooser.saveButton.textAndMnemonic=Enregistrer
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Enregistrer
|
FileChooser.saveDialogTitle.textAndMnemonic=Enregistrer
|
||||||
FileChooser.openDialogTitleText=Ouvrir
|
FileChooser.openDialogTitle.textAndMnemonic=Ouvrir
|
||||||
FileChooser.updateButtonText=Mettre \u00E0 jour
|
FileChooser.updateButton.textAndMnemonic=Mettre \u00E0 jour
|
||||||
FileChooser.helpButtonText=Aide
|
FileChooser.helpButton.textAndMnemonic=Aide
|
||||||
FileChooser.pathLabelText=Entrez le chemin ou le nom du dossier :
|
FileChooser.pathLabel.textAndMnemonic=Entrez le chemin ou le nom du dossier (&P):
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filt&re
|
||||||
FileChooser.filterLabelText=Filtre
|
FileChooser.foldersLabel.textAndMnemonic=Dossiers(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=F&ichiers
|
||||||
FileChooser.foldersLabelText=Dossiers
|
FileChooser.enterFileNameLabel.textAndMnemonic=E&ntrez le nom du fichier :
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Entrez le nom du dossier :
|
||||||
FileChooser.filesLabelText=Fichiers
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Entrez le nom du fichier :
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Entrez le nom du dossier :
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Ferme la bo\u00EEte de dialogue du s\u00E9lecteur de fichiers.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Ferme la bo\u00EEte de dialogue du s\u00E9lecteur de fichiers.
|
||||||
FileChooser.saveButtonToolTipText=Enregistre le fichier s\u00E9lectionn\u00E9.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Enregistre le fichier s\u00E9lectionn\u00E9.
|
||||||
FileChooser.openButtonToolTipText=Ouvre le fichier s\u00E9lectionn\u00E9.
|
FileChooser.openButtonToolTip.textAndMnemonic=Ouvre le fichier s\u00E9lectionn\u00E9.
|
||||||
FileChooser.updateButtonToolTipText=Met \u00E0 jour la liste des r\u00E9pertoires.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Met \u00E0 jour la liste des r\u00E9pertoires.
|
||||||
FileChooser.helpButtonToolTipText=Aide du s\u00E9lecteur de fichiers
|
FileChooser.helpButtonToolTip.textAndMnemonic=Aide du s\u00E9lecteur de fichiers
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Annulla
|
FileChooser.cancelButton.textAndMnemonic=Annulla
|
||||||
FileChooser.saveButtonText=Salva
|
FileChooser.saveButton.textAndMnemonic=Salva
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Salva
|
FileChooser.saveDialogTitle.textAndMnemonic=Salva
|
||||||
FileChooser.openDialogTitleText=Apri
|
FileChooser.openDialogTitle.textAndMnemonic=Apri
|
||||||
FileChooser.updateButtonText=Aggiorna
|
FileChooser.updateButton.textAndMnemonic=Aggiorna
|
||||||
FileChooser.helpButtonText=?
|
FileChooser.helpButton.textAndMnemonic=?
|
||||||
FileChooser.pathLabelText=Percorso o nome cartella:
|
FileChooser.pathLabel.textAndMnemonic=&Percorso o nome cartella:
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filt&ro
|
||||||
FileChooser.filterLabelText=Filtro
|
FileChooser.foldersLabel.textAndMnemonic=Carte&lle
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=F&ile
|
||||||
FileChooser.foldersLabelText=Cartelle
|
FileChooser.enterFileNameLabel.textAndMnemonic=&Nome file:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Nome cartella:
|
||||||
FileChooser.filesLabelText=File
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Nome file:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Nome cartella:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Chiude la finestra di dialogo di selezione file.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Chiude la finestra di dialogo di selezione file.
|
||||||
FileChooser.saveButtonToolTipText=Salva il file selezionato.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Salva il file selezionato.
|
||||||
FileChooser.openButtonToolTipText=Apre il file selezionato.
|
FileChooser.openButtonToolTip.textAndMnemonic=Apre il file selezionato.
|
||||||
FileChooser.updateButtonToolTipText=Aggiorna lista directory.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Aggiorna lista directory.
|
||||||
FileChooser.helpButtonToolTipText=Guida FileChooser.
|
FileChooser.helpButtonToolTip.textAndMnemonic=Guida FileChooser.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=\u53D6\u6D88
|
FileChooser.cancelButton.textAndMnemonic=\u53D6\u6D88
|
||||||
FileChooser.saveButtonText=\u4FDD\u5B58
|
FileChooser.saveButton.textAndMnemonic=\u4FDD\u5B58
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=\u4FDD\u5B58
|
FileChooser.saveDialogTitle.textAndMnemonic=\u4FDD\u5B58
|
||||||
FileChooser.openDialogTitleText=\u958B\u304F
|
FileChooser.openDialogTitle.textAndMnemonic=\u958B\u304F
|
||||||
FileChooser.updateButtonText=\u66F4\u65B0
|
FileChooser.updateButton.textAndMnemonic=\u66F4\u65B0
|
||||||
FileChooser.helpButtonText=\u30D8\u30EB\u30D7
|
FileChooser.helpButton.textAndMnemonic=\u30D8\u30EB\u30D7
|
||||||
FileChooser.pathLabelText=\u30D1\u30B9\u307E\u305F\u306F\u30D5\u30A9\u30EB\u30C0\u540D\u3092\u5165\u529B:
|
FileChooser.pathLabel.textAndMnemonic=\u30D1\u30B9\u307E\u305F\u306F\u30D5\u30A9\u30EB\u30C0\u540D\u3092\u5165\u529B(&P):
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=\u30D5\u30A3\u30EB\u30BF(&R)
|
||||||
FileChooser.filterLabelText=\u30D5\u30A3\u30EB\u30BF
|
FileChooser.foldersLabel.textAndMnemonic=\u30D5\u30A9\u30EB\u30C0(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=\u30D5\u30A1\u30A4\u30EB(&I)
|
||||||
FileChooser.foldersLabelText=\u30D5\u30A9\u30EB\u30C0
|
FileChooser.enterFileNameLabel.textAndMnemonic=\u30D5\u30A1\u30A4\u30EB\u540D\u3092\u5165\u529B(&N):
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=\u30D5\u30A9\u30EB\u30C0\u540D\u3092\u5165\u529B:
|
||||||
FileChooser.filesLabelText=\u30D5\u30A1\u30A4\u30EB
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=\u30D5\u30A1\u30A4\u30EB\u540D\u3092\u5165\u529B:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=\u30D5\u30A9\u30EB\u30C0\u540D\u3092\u5165\u529B:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=\u30D5\u30A1\u30A4\u30EB\u30FB\u30C1\u30E5\u30FC\u30B6\u30FB\u30C0\u30A4\u30A2\u30ED\u30B0\u3092\u7D42\u4E86\u3057\u307E\u3059\u3002
|
FileChooser.cancelButtonToolTip.textAndMnemonic=\u30D5\u30A1\u30A4\u30EB\u30FB\u30C1\u30E5\u30FC\u30B6\u30FB\u30C0\u30A4\u30A2\u30ED\u30B0\u3092\u7D42\u4E86\u3057\u307E\u3059\u3002
|
||||||
FileChooser.saveButtonToolTipText=\u9078\u629E\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u3092\u4FDD\u5B58\u3057\u307E\u3059\u3002
|
FileChooser.saveButtonToolTip.textAndMnemonic=\u9078\u629E\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u3092\u4FDD\u5B58\u3057\u307E\u3059\u3002
|
||||||
FileChooser.openButtonToolTipText=\u9078\u629E\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u3092\u958B\u304D\u307E\u3059\u3002
|
FileChooser.openButtonToolTip.textAndMnemonic=\u9078\u629E\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u3092\u958B\u304D\u307E\u3059\u3002
|
||||||
FileChooser.updateButtonToolTipText=\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30EA\u30B9\u30C8\u3092\u66F4\u65B0\u3057\u307E\u3059\u3002
|
FileChooser.updateButtonToolTip.textAndMnemonic=\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30EA\u30B9\u30C8\u3092\u66F4\u65B0\u3057\u307E\u3059\u3002
|
||||||
FileChooser.helpButtonToolTipText=FileChooser\u306E\u30D8\u30EB\u30D7\u3067\u3059\u3002
|
FileChooser.helpButtonToolTip.textAndMnemonic=FileChooser\u306E\u30D8\u30EB\u30D7\u3067\u3059\u3002
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=\uCDE8\uC18C
|
FileChooser.cancelButton.textAndMnemonic=\uCDE8\uC18C
|
||||||
FileChooser.saveButtonText=\uC800\uC7A5
|
FileChooser.saveButton.textAndMnemonic=\uC800\uC7A5
|
||||||
FileChooser.openButtonText=\uD655\uC778
|
FileChooser.openButton.textAndMnemonic=\uD655\uC778
|
||||||
FileChooser.saveDialogTitleText=\uC800\uC7A5
|
FileChooser.saveDialogTitle.textAndMnemonic=\uC800\uC7A5
|
||||||
FileChooser.openDialogTitleText=\uC5F4\uAE30
|
FileChooser.openDialogTitle.textAndMnemonic=\uC5F4\uAE30
|
||||||
FileChooser.updateButtonText=\uAC31\uC2E0
|
FileChooser.updateButton.textAndMnemonic=\uAC31\uC2E0
|
||||||
FileChooser.helpButtonText=\uB3C4\uC6C0\uB9D0
|
FileChooser.helpButton.textAndMnemonic=\uB3C4\uC6C0\uB9D0
|
||||||
FileChooser.pathLabelText=\uACBD\uB85C \uB610\uB294 \uD3F4\uB354 \uC774\uB984 \uC785\uB825:
|
FileChooser.pathLabel.textAndMnemonic=\uACBD\uB85C \uB610\uB294 \uD3F4\uB354 \uC774\uB984 \uC785\uB825(&P):
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=\uD544\uD130(&R)
|
||||||
FileChooser.filterLabelText=\uD544\uD130
|
FileChooser.foldersLabel.textAndMnemonic=\uD3F4\uB354(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=\uD30C\uC77C(&I)
|
||||||
FileChooser.foldersLabelText=\uD3F4\uB354
|
FileChooser.enterFileNameLabel.textAndMnemonic=\uD30C\uC77C \uC774\uB984 \uC785\uB825(&N):
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=\uD3F4\uB354 \uC774\uB984 \uC785\uB825:
|
||||||
FileChooser.filesLabelText=\uD30C\uC77C
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=\uD30C\uC77C \uC774\uB984 \uC785\uB825:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=\uD3F4\uB354 \uC774\uB984 \uC785\uB825:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=\uD30C\uC77C \uC120\uD0DD\uAE30 \uB300\uD654\uC0C1\uC790\uB97C \uC911\uB2E8\uD569\uB2C8\uB2E4.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=\uD30C\uC77C \uC120\uD0DD\uAE30 \uB300\uD654\uC0C1\uC790\uB97C \uC911\uB2E8\uD569\uB2C8\uB2E4.
|
||||||
FileChooser.saveButtonToolTipText=\uC120\uD0DD\uB41C \uD30C\uC77C\uC744 \uC800\uC7A5\uD569\uB2C8\uB2E4.
|
FileChooser.saveButtonToolTip.textAndMnemonic=\uC120\uD0DD\uB41C \uD30C\uC77C\uC744 \uC800\uC7A5\uD569\uB2C8\uB2E4.
|
||||||
FileChooser.openButtonToolTipText=\uC120\uD0DD\uB41C \uD30C\uC77C\uC744 \uC5FD\uB2C8\uB2E4.
|
FileChooser.openButtonToolTip.textAndMnemonic=\uC120\uD0DD\uB41C \uD30C\uC77C\uC744 \uC5FD\uB2C8\uB2E4.
|
||||||
FileChooser.updateButtonToolTipText=\uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC744 \uAC31\uC2E0\uD569\uB2C8\uB2E4.
|
FileChooser.updateButtonToolTip.textAndMnemonic=\uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC744 \uAC31\uC2E0\uD569\uB2C8\uB2E4.
|
||||||
FileChooser.helpButtonToolTipText=FileChooser \uB3C4\uC6C0\uB9D0\uC785\uB2C8\uB2E4.
|
FileChooser.helpButtonToolTip.textAndMnemonic=FileChooser \uB3C4\uC6C0\uB9D0\uC785\uB2C8\uB2E4.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Cancelar
|
FileChooser.cancelButton.textAndMnemonic=Cancelar
|
||||||
FileChooser.saveButtonText=Salvar
|
FileChooser.saveButton.textAndMnemonic=Salvar
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Salvar
|
FileChooser.saveDialogTitle.textAndMnemonic=Salvar
|
||||||
FileChooser.openDialogTitleText=Abrir
|
FileChooser.openDialogTitle.textAndMnemonic=Abrir
|
||||||
FileChooser.updateButtonText=Atualizar
|
FileChooser.updateButton.textAndMnemonic=Atualizar
|
||||||
FileChooser.helpButtonText=Ajuda
|
FileChooser.helpButton.textAndMnemonic=Ajuda
|
||||||
FileChooser.pathLabelText=Informar caminho ou nome da pasta:
|
FileChooser.pathLabel.textAndMnemonic=Informar caminho ou nome da &pasta:
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filt&ro
|
||||||
FileChooser.filterLabelText=Filtro
|
FileChooser.foldersLabel.textAndMnemonic=Pastas(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=Arqu&ivos
|
||||||
FileChooser.foldersLabelText=Pastas
|
FileChooser.enterFileNameLabel.textAndMnemonic=I&nformar nome do arquivo:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Informar nome da pasta:
|
||||||
FileChooser.filesLabelText=Arquivos
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Informar nome do arquivo:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Informar nome da pasta:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Abortar caixa de di\u00E1logo do seletor de arquivos.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Abortar caixa de di\u00E1logo do seletor de arquivos.
|
||||||
FileChooser.saveButtonToolTipText=Salvar arquivo selecionado.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Salvar arquivo selecionado.
|
||||||
FileChooser.openButtonToolTipText=Abrir arquivo selecionado.
|
FileChooser.openButtonToolTip.textAndMnemonic=Abrir arquivo selecionado.
|
||||||
FileChooser.updateButtonToolTipText=Atualizar lista de diret\u00F3rios.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Atualizar lista de diret\u00F3rios.
|
||||||
FileChooser.helpButtonToolTipText=Ajuda do FileChooser.
|
FileChooser.helpButtonToolTip.textAndMnemonic=Ajuda do FileChooser.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=Avbryt
|
FileChooser.cancelButton.textAndMnemonic=Avbryt
|
||||||
FileChooser.saveButtonText=Spara
|
FileChooser.saveButton.textAndMnemonic=Spara
|
||||||
FileChooser.openButtonText=OK
|
FileChooser.openButton.textAndMnemonic=OK
|
||||||
FileChooser.saveDialogTitleText=Spara
|
FileChooser.saveDialogTitle.textAndMnemonic=Spara
|
||||||
FileChooser.openDialogTitleText=\u00D6ppna
|
FileChooser.openDialogTitle.textAndMnemonic=\u00D6ppna
|
||||||
FileChooser.updateButtonText=Uppdatera
|
FileChooser.updateButton.textAndMnemonic=Uppdatera
|
||||||
FileChooser.helpButtonText=Hj\u00E4lp
|
FileChooser.helpButton.textAndMnemonic=Hj\u00E4lp
|
||||||
FileChooser.pathLabelText=Ange s\u00F6kv\u00E4g eller mappnamn:
|
FileChooser.pathLabel.textAndMnemonic=Ange s\u00F6kv\u00E4g eller mappnamn(&P):
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=Filte&r
|
||||||
FileChooser.filterLabelText=Filter
|
FileChooser.foldersLabel.textAndMnemonic=Mappar(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=F&iler
|
||||||
FileChooser.foldersLabelText=Mappar
|
FileChooser.enterFileNameLabel.textAndMnemonic=A&nge filnamn:
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=Ange ett mappnamn:
|
||||||
FileChooser.filesLabelText=Filer
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=Ange filnamn:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=Ange ett mappnamn:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=Avbryt dialogrutan Filv\u00E4ljare.
|
FileChooser.cancelButtonToolTip.textAndMnemonic=Avbryt dialogrutan Filv\u00E4ljare.
|
||||||
FileChooser.saveButtonToolTipText=Spara vald fil.
|
FileChooser.saveButtonToolTip.textAndMnemonic=Spara vald fil.
|
||||||
FileChooser.openButtonToolTipText=\u00D6ppna vald fil.
|
FileChooser.openButtonToolTip.textAndMnemonic=\u00D6ppna vald fil.
|
||||||
FileChooser.updateButtonToolTipText=Uppdatera kataloglistan.
|
FileChooser.updateButtonToolTip.textAndMnemonic=Uppdatera kataloglistan.
|
||||||
FileChooser.helpButtonToolTipText=Hj\u00E4lp - Filv\u00E4ljare.
|
FileChooser.helpButtonToolTip.textAndMnemonic=Hj\u00E4lp - Filv\u00E4ljare.
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=\u53D6\u6D88
|
FileChooser.cancelButton.textAndMnemonic=\u53D6\u6D88
|
||||||
FileChooser.saveButtonText=\u4FDD\u5B58
|
FileChooser.saveButton.textAndMnemonic=\u4FDD\u5B58
|
||||||
FileChooser.openButtonText=\u786E\u5B9A
|
FileChooser.openButton.textAndMnemonic=\u786E\u5B9A
|
||||||
FileChooser.saveDialogTitleText=\u4FDD\u5B58
|
FileChooser.saveDialogTitle.textAndMnemonic=\u4FDD\u5B58
|
||||||
FileChooser.openDialogTitleText=\u6253\u5F00
|
FileChooser.openDialogTitle.textAndMnemonic=\u6253\u5F00
|
||||||
FileChooser.updateButtonText=\u66F4\u65B0
|
FileChooser.updateButton.textAndMnemonic=\u66F4\u65B0
|
||||||
FileChooser.helpButtonText=\u5E2E\u52A9
|
FileChooser.helpButton.textAndMnemonic=\u5E2E\u52A9
|
||||||
FileChooser.pathLabelText=\u952E\u5165\u8DEF\u5F84\u6216\u6587\u4EF6\u5939\u540D:
|
FileChooser.pathLabel.textAndMnemonic=\u952E\u5165\u8DEF\u5F84\u6216\u6587\u4EF6\u5939\u540D: (&P)
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=\u7B5B\u9009\u5668(&R)
|
||||||
FileChooser.filterLabelText=\u7B5B\u9009\u5668
|
FileChooser.foldersLabel.textAndMnemonic=\u6587\u4EF6\u5939(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=\u6587\u4EF6(&I)
|
||||||
FileChooser.foldersLabelText=\u6587\u4EF6\u5939
|
FileChooser.enterFileNameLabel.textAndMnemonic=\u952E\u5165\u6587\u4EF6\u540D: (&N)
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=\u8F93\u5165\u6587\u4EF6\u5939\u540D:
|
||||||
FileChooser.filesLabelText=\u6587\u4EF6
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=\u952E\u5165\u6587\u4EF6\u540D:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=\u8F93\u5165\u6587\u4EF6\u5939\u540D:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=\u4E2D\u6B62\u6587\u4EF6\u9009\u62E9\u5668\u5BF9\u8BDD\u6846\u3002
|
FileChooser.cancelButtonToolTip.textAndMnemonic=\u4E2D\u6B62\u6587\u4EF6\u9009\u62E9\u5668\u5BF9\u8BDD\u6846\u3002
|
||||||
FileChooser.saveButtonToolTipText=\u4FDD\u5B58\u6240\u9009\u6587\u4EF6\u3002
|
FileChooser.saveButtonToolTip.textAndMnemonic=\u4FDD\u5B58\u6240\u9009\u6587\u4EF6\u3002
|
||||||
FileChooser.openButtonToolTipText=\u6253\u5F00\u6240\u9009\u6587\u4EF6\u3002
|
FileChooser.openButtonToolTip.textAndMnemonic=\u6253\u5F00\u6240\u9009\u6587\u4EF6\u3002
|
||||||
FileChooser.updateButtonToolTipText=\u66F4\u65B0\u76EE\u5F55\u5217\u8868\u3002
|
FileChooser.updateButtonToolTip.textAndMnemonic=\u66F4\u65B0\u76EE\u5F55\u5217\u8868\u3002
|
||||||
FileChooser.helpButtonToolTipText=FileChooser \u5E2E\u52A9\u3002
|
FileChooser.helpButtonToolTip.textAndMnemonic=FileChooser \u5E2E\u52A9\u3002
|
||||||
|
@ -18,28 +18,23 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.acceptAllFileFilterText=*
|
FileChooser.acceptAllFileFilter.textAndMnemonic=*
|
||||||
FileChooser.cancelButtonText=\u53D6\u6D88
|
FileChooser.cancelButton.textAndMnemonic=\u53D6\u6D88
|
||||||
FileChooser.saveButtonText=\u5132\u5B58
|
FileChooser.saveButton.textAndMnemonic=\u5132\u5B58
|
||||||
FileChooser.openButtonText=\u78BA\u5B9A
|
FileChooser.openButton.textAndMnemonic=\u78BA\u5B9A
|
||||||
FileChooser.saveDialogTitleText=\u5132\u5B58
|
FileChooser.saveDialogTitle.textAndMnemonic=\u5132\u5B58
|
||||||
FileChooser.openDialogTitleText=\u958B\u555F
|
FileChooser.openDialogTitle.textAndMnemonic=\u958B\u555F
|
||||||
FileChooser.updateButtonText=\u66F4\u65B0
|
FileChooser.updateButton.textAndMnemonic=\u66F4\u65B0
|
||||||
FileChooser.helpButtonText=\u8AAA\u660E
|
FileChooser.helpButton.textAndMnemonic=\u8AAA\u660E
|
||||||
FileChooser.pathLabelText=\u8F38\u5165\u8DEF\u5F91\u6216\u8CC7\u6599\u593E\u540D\u7A31:
|
FileChooser.pathLabel.textAndMnemonic=\u8F38\u5165\u8DEF\u5F91\u6216\u8CC7\u6599\u593E\u540D\u7A31(&P):
|
||||||
FileChooser.pathLabelMnemonic=80
|
FileChooser.filterLabel.textAndMnemonic=\u7BE9\u9078(&R)
|
||||||
FileChooser.filterLabelText=\u7BE9\u9078
|
FileChooser.foldersLabel.textAndMnemonic=\u8CC7\u6599\u593E(&L)
|
||||||
FileChooser.filterLabelMnemonic=82
|
FileChooser.filesLabel.textAndMnemonic=\u6A94\u6848(&I)
|
||||||
FileChooser.foldersLabelText=\u8CC7\u6599\u593E
|
FileChooser.enterFileNameLabel.textAndMnemonic=\u8F38\u5165\u6A94\u6848\u540D\u7A31(&N):
|
||||||
FileChooser.foldersLabelMnemonic=76
|
FileChooser.enterFolderNameLabel.textAndMnemonic=\u8F38\u5165\u8CC7\u6599\u593E\u540D\u7A31:
|
||||||
FileChooser.filesLabelText=\u6A94\u6848
|
|
||||||
FileChooser.filesLabelMnemonic=73
|
|
||||||
FileChooser.enterFileNameLabelText=\u8F38\u5165\u6A94\u6848\u540D\u7A31:
|
|
||||||
FileChooser.enterFileNameLabelMnemonic=78
|
|
||||||
FileChooser.enterFolderNameLabelText=\u8F38\u5165\u8CC7\u6599\u593E\u540D\u7A31:
|
|
||||||
|
|
||||||
FileChooser.cancelButtonToolTipText=\u4E2D\u6B62\u6A94\u6848\u9078\u64C7\u5668\u5C0D\u8A71\u65B9\u584A\u3002
|
FileChooser.cancelButtonToolTip.textAndMnemonic=\u4E2D\u6B62\u6A94\u6848\u9078\u64C7\u5668\u5C0D\u8A71\u65B9\u584A\u3002
|
||||||
FileChooser.saveButtonToolTipText=\u5132\u5B58\u9078\u53D6\u7684\u6A94\u6848\u3002
|
FileChooser.saveButtonToolTip.textAndMnemonic=\u5132\u5B58\u9078\u53D6\u7684\u6A94\u6848\u3002
|
||||||
FileChooser.openButtonToolTipText=\u958B\u555F\u9078\u53D6\u7684\u6A94\u6848\u3002
|
FileChooser.openButtonToolTip.textAndMnemonic=\u958B\u555F\u9078\u53D6\u7684\u6A94\u6848\u3002
|
||||||
FileChooser.updateButtonToolTipText=\u66F4\u65B0\u76EE\u9304\u6E05\u55AE\u3002
|
FileChooser.updateButtonToolTip.textAndMnemonic=\u66F4\u65B0\u76EE\u9304\u6E05\u55AE\u3002
|
||||||
FileChooser.helpButtonToolTipText=\u300C\u6A94\u6848\u9078\u64C7\u5668\u300D\u8AAA\u660E\u3002
|
FileChooser.helpButtonToolTip.textAndMnemonic=\u300C\u6A94\u6848\u9078\u64C7\u5668\u300D\u8AAA\u660E\u3002
|
||||||
|
@ -18,34 +18,30 @@
|
|||||||
|
|
||||||
############ FILE CHOOSER STRINGS #############
|
############ FILE CHOOSER STRINGS #############
|
||||||
|
|
||||||
FileChooser.lookInLabelText=Look in:
|
FileChooser.lookInLabel.textAndMnemonic=Look &in:
|
||||||
FileChooser.lookInLabelMnemonic=73
|
FileChooser.saveInLabel.textAndMnemonic=Save in:
|
||||||
FileChooser.saveInLabelText=Save in:
|
FileChooser.fileNameLabel.textAndMnemonic=File &name:
|
||||||
FileChooser.fileNameLabelText=File name:
|
FileChooser.folderNameLabel.textAndMnemonic=Folder &name:
|
||||||
FileChooser.fileNameLabelMnemonic=78
|
FileChooser.filesOfTypeLabel.textAndMnemonic=Files of &type:
|
||||||
FileChooser.folderNameLabelText=Folder name:
|
FileChooser.upFolderToolTip.textAndMnemonic=Up One Level
|
||||||
FileChooser.folderNameLabelMnemonic=78
|
|
||||||
FileChooser.filesOfTypeLabelText=Files of type:
|
|
||||||
FileChooser.filesOfTypeLabelMnemonic=84
|
|
||||||
FileChooser.upFolderToolTipText=Up One Level
|
|
||||||
FileChooser.upFolderAccessibleName=Up
|
FileChooser.upFolderAccessibleName=Up
|
||||||
FileChooser.homeFolderToolTipText=Home
|
FileChooser.homeFolderToolTip.textAndMnemonic=Home
|
||||||
FileChooser.homeFolderAccessibleName=Home
|
FileChooser.homeFolderAccessibleName=Home
|
||||||
FileChooser.newFolderToolTipText=Create New Folder
|
FileChooser.newFolderToolTip.textAndMnemonic=Create New Folder
|
||||||
FileChooser.newFolderAccessibleName=New Folder
|
FileChooser.newFolderAccessibleName=New Folder
|
||||||
FileChooser.newFolderActionLabelText=New Folder
|
FileChooser.newFolderActionLabel.textAndMnemonic=New Folder
|
||||||
FileChooser.listViewButtonToolTipText=List
|
FileChooser.listViewButtonToolTip.textAndMnemonic=List
|
||||||
FileChooser.listViewButtonAccessibleName=List
|
FileChooser.listViewButtonAccessibleName=List
|
||||||
FileChooser.listViewActionLabelText=List
|
FileChooser.listViewActionLabel.textAndMnemonic=List
|
||||||
FileChooser.detailsViewButtonToolTipText=Details
|
FileChooser.detailsViewButtonToolTip.textAndMnemonic=Details
|
||||||
FileChooser.detailsViewButtonAccessibleName=Details
|
FileChooser.detailsViewButtonAccessibleName=Details
|
||||||
FileChooser.viewMenuButtonToolTipText = View Menu
|
FileChooser.viewMenuButtonToolTipText = View Menu
|
||||||
FileChooser.viewMenuButtonAccessibleName = View Menu
|
FileChooser.viewMenuButtonAccessibleName = View Menu
|
||||||
FileChooser.detailsViewActionLabelText=Details
|
FileChooser.detailsViewActionLabel.textAndMnemonic=Details
|
||||||
FileChooser.refreshActionLabelText=Refresh
|
FileChooser.refreshActionLabel.textAndMnemonic=Refresh
|
||||||
FileChooser.viewMenuLabelText=View
|
FileChooser.viewMenuLabel.textAndMnemonic=View
|
||||||
FileChooser.fileNameHeaderText=Name
|
FileChooser.fileNameHeader.textAndMnemonic=Name
|
||||||
FileChooser.fileSizeHeaderText=Size
|
FileChooser.fileSizeHeader.textAndMnemonic=Size
|
||||||
FileChooser.fileTypeHeaderText=Type
|
FileChooser.fileTypeHeader.textAndMnemonic=Type
|
||||||
FileChooser.fileDateHeaderText=Modified
|
FileChooser.fileDateHeader.textAndMnemonic=Modified
|
||||||
FileChooser.fileAttrHeaderText=Attributes
|
FileChooser.fileAttrHeader.textAndMnemonic=Attributes
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user