mirror of
https://github.com/corda/corda.git
synced 2025-01-03 19:54:13 +00:00
fix Windows openjdk-src build
This commit is contained in:
parent
70a36c05b9
commit
8de53aeacc
9
makefile
9
makefile
@ -86,9 +86,11 @@ ifneq ($(openjdk),)
|
|||||||
openjdk-jar-dep = $(build)/openjdk-jar.dep
|
openjdk-jar-dep = $(build)/openjdk-jar.dep
|
||||||
classpath-jar-dep = $(openjdk-jar-dep)
|
classpath-jar-dep = $(openjdk-jar-dep)
|
||||||
javahome = $(embed-prefix)/javahomeJar
|
javahome = $(embed-prefix)/javahomeJar
|
||||||
javahome-files = lib/zi lib/currency.data
|
javahome-files = lib/zi
|
||||||
ifeq ($(platform),windows)
|
ifeq ($(platform),windows)
|
||||||
javahome-files += lib/tzmappings
|
javahome-files += lib/tzmappings
|
||||||
|
else
|
||||||
|
javahome-files += lib/currency.data
|
||||||
endif
|
endif
|
||||||
javahome-object = $(build)/javahome-jar.o
|
javahome-object = $(build)/javahome-jar.o
|
||||||
else
|
else
|
||||||
@ -835,6 +837,11 @@ $(openjdk-headers-dep):
|
|||||||
@mkdir -p $(dir $(@))
|
@mkdir -p $(dir $(@))
|
||||||
$(javah) -d $(build)/openjdk -bootclasspath $(boot-classpath) \
|
$(javah) -d $(build)/openjdk -bootclasspath $(boot-classpath) \
|
||||||
$(openjdk-headers-classes)
|
$(openjdk-headers-classes)
|
||||||
|
ifeq ($(platform),windows)
|
||||||
|
sed 's/^#ifdef _WIN64/#if 1/' \
|
||||||
|
< "$(openjdk-src)/windows/native/java/net/net_util_md.h" \
|
||||||
|
> $(build)/openjdk/net_util_md.h
|
||||||
|
endif
|
||||||
@touch $(@)
|
@touch $(@)
|
||||||
|
|
||||||
$(openjdk-jar-dep):
|
$(openjdk-jar-dep):
|
||||||
|
@ -131,14 +131,14 @@ openjdk-headers-classes = \
|
|||||||
sun.nio.ch.Net \
|
sun.nio.ch.Net \
|
||||||
sun.nio.ch.ServerSocketChannelImpl \
|
sun.nio.ch.ServerSocketChannelImpl \
|
||||||
sun.nio.ch.SocketChannelImpl \
|
sun.nio.ch.SocketChannelImpl \
|
||||||
sun.nio.ch.EPollArrayWrapper \
|
sun.nio.ch.SocketDispatcher \
|
||||||
sun.nio.ch.PollArrayWrapper \
|
sun.nio.ch.PollArrayWrapper \
|
||||||
sun.nio.ch.InheritedChannel \
|
|
||||||
sun.nio.ch.NativeThread \
|
sun.nio.ch.NativeThread \
|
||||||
sun.reflect.ConstantPool \
|
sun.reflect.ConstantPool \
|
||||||
sun.reflect.NativeConstructorAccessorImpl \
|
sun.reflect.NativeConstructorAccessorImpl \
|
||||||
sun.reflect.NativeMethodAccessorImpl \
|
sun.reflect.NativeMethodAccessorImpl \
|
||||||
sun.reflect.Reflection \
|
sun.reflect.Reflection \
|
||||||
|
sun.security.provider.NativeSeedGenerator
|
||||||
|
|
||||||
# todo: set properties according to architecture targeted and OpenJDK
|
# todo: set properties according to architecture targeted and OpenJDK
|
||||||
# version used:
|
# version used:
|
||||||
@ -183,19 +183,38 @@ ifeq ($(platform),windows)
|
|||||||
$(openjdk-src)/windows/native/java/io/WinNTFileSystem_md.c \
|
$(openjdk-src)/windows/native/java/io/WinNTFileSystem_md.c \
|
||||||
$(openjdk-src)/windows/native/java/lang/java_props_md.c \
|
$(openjdk-src)/windows/native/java/lang/java_props_md.c \
|
||||||
$(openjdk-src)/windows/native/java/lang/ProcessEnvironment_md.c \
|
$(openjdk-src)/windows/native/java/lang/ProcessEnvironment_md.c \
|
||||||
|
$(openjdk-src)/windows/native/java/net/net_util_md.c \
|
||||||
$(openjdk-src)/windows/native/java/net/InetAddressImplFactory.c \
|
$(openjdk-src)/windows/native/java/net/InetAddressImplFactory.c \
|
||||||
$(openjdk-src)/windows/native/java/net/Inet4AddressImpl.c \
|
$(openjdk-src)/windows/native/java/net/Inet4AddressImpl.c \
|
||||||
$(openjdk-src)/windows/native/java/net/Inet6AddressImpl.c \
|
$(openjdk-src)/windows/native/java/net/Inet6AddressImpl.c \
|
||||||
$(openjdk-src)/windows/native/java/net/NetworkInterface.c \
|
$(openjdk-src)/windows/native/java/net/NetworkInterface.c \
|
||||||
|
$(openjdk-src)/windows/native/java/net/NetworkInterface_winXP.c \
|
||||||
|
$(openjdk-src)/windows/native/java/net/NetworkInterface_win9x.c \
|
||||||
|
$(openjdk-src)/windows/native/java/net/SocketInputStream.c \
|
||||||
|
$(openjdk-src)/windows/native/java/net/SocketOutputStream.c \
|
||||||
$(openjdk-src)/windows/native/java/util/WindowsPreferences.c \
|
$(openjdk-src)/windows/native/java/util/WindowsPreferences.c \
|
||||||
$(openjdk-src)/windows/native/java/util/logging.c \
|
$(openjdk-src)/windows/native/java/util/logging.c \
|
||||||
$(openjdk-src)/windows/native/java/util/TimeZone_md.c \
|
$(openjdk-src)/windows/native/java/util/TimeZone_md.c \
|
||||||
$(openjdk-src)/windows/native/sun/io/Win32ErrorMode.c \
|
$(openjdk-src)/windows/native/sun/io/Win32ErrorMode.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/DatagramChannelImpl.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/DatagramDispatcher.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/FileChannelImpl.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/FileDispatcher.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/FileKey.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/IOUtil.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/Net.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/ServerSocketChannelImpl.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/SocketChannelImpl.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/SocketDispatcher.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/nio/ch/WindowsSelectorImpl.c \
|
||||||
|
$(openjdk-src)/windows/native/sun/security/provider/WinCAPISeedGenerator.c
|
||||||
|
|
||||||
openjdk-headers-classes += \
|
openjdk-headers-classes += \
|
||||||
sun.io.Win32ErrorMode
|
sun.io.Win32ErrorMode \
|
||||||
|
sun.nio.ch.WindowsSelectorImpl \
|
||||||
|
|
||||||
openjdk-cflags += "-I$(openjdk-src)/windows/javavm/export" \
|
openjdk-cflags += \
|
||||||
|
"-I$(openjdk-src)/windows/javavm/export" \
|
||||||
"-I$(openjdk-src)/windows/native/common" \
|
"-I$(openjdk-src)/windows/native/common" \
|
||||||
"-I$(openjdk-src)/windows/native/java/io" \
|
"-I$(openjdk-src)/windows/native/java/io" \
|
||||||
"-I$(openjdk-src)/windows/native/java/net" \
|
"-I$(openjdk-src)/windows/native/java/net" \
|
||||||
@ -203,7 +222,10 @@ ifeq ($(platform),windows)
|
|||||||
"-I$(openjdk-src)/windows/javavm/include" \
|
"-I$(openjdk-src)/windows/javavm/include" \
|
||||||
"-I$(root)/win32/include" \
|
"-I$(root)/win32/include" \
|
||||||
-D_JNI_IMPLEMENTATION_ \
|
-D_JNI_IMPLEMENTATION_ \
|
||||||
-D_JAVASOFT_WIN32_TYPEDEF_MD_H_
|
-D_JAVASOFT_WIN32_TYPEDEF_MD_H_ \
|
||||||
|
-D_WINSOCK2API_ \
|
||||||
|
-Ds6_words=_s6_words \
|
||||||
|
-Ds6_bytes=_s6_bytes
|
||||||
else
|
else
|
||||||
openjdk-sources += \
|
openjdk-sources += \
|
||||||
$(openjdk-src)/solaris/native/common/jdk_util_md.c \
|
$(openjdk-src)/solaris/native/common/jdk_util_md.c \
|
||||||
@ -251,7 +273,9 @@ else
|
|||||||
$(openjdk-src)/solaris/native/sun/nio/ch/NativeThread.c \
|
$(openjdk-src)/solaris/native/sun/nio/ch/NativeThread.c \
|
||||||
|
|
||||||
openjdk-headers-classes += \
|
openjdk-headers-classes += \
|
||||||
java.io.UnixFileSystem
|
java.io.UnixFileSystem \
|
||||||
|
sun.nio.ch.InheritedChannel \
|
||||||
|
sun.nio.ch.EPollArrayWrapper \
|
||||||
|
|
||||||
openjdk-cflags += "-I$(openjdk-src)/solaris/javavm/export" \
|
openjdk-cflags += "-I$(openjdk-src)/solaris/javavm/export" \
|
||||||
"-I$(openjdk-src)/solaris/native/common" \
|
"-I$(openjdk-src)/solaris/native/common" \
|
||||||
|
17
src/main.cpp
17
src/main.cpp
@ -59,6 +59,11 @@ class RuntimeArray {
|
|||||||
// ourselves:
|
// ourselves:
|
||||||
extern "C" void __cxa_pure_virtual(void) { abort(); }
|
extern "C" void __cxa_pure_virtual(void) { abort(); }
|
||||||
|
|
||||||
|
// we link against a System implmentation, which requires this at link
|
||||||
|
// time, but it should not be used at runtime:
|
||||||
|
extern "C" uint64_t
|
||||||
|
vmNativeCall(void*, void*, unsigned, unsigned) { abort(); }
|
||||||
|
|
||||||
#endif // BOOT_LIBRARY
|
#endif // BOOT_LIBRARY
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
@ -111,19 +116,21 @@ mainClass(const char* jar)
|
|||||||
|
|
||||||
Finder* finder = makeFinder(system, &allocator, jar, 0);
|
Finder* finder = makeFinder(system, &allocator, jar, 0);
|
||||||
|
|
||||||
const char* result = 0;
|
char* result = 0;
|
||||||
|
|
||||||
System::Region* region = finder->find("META-INF/MANIFEST.MF");
|
System::Region* region = finder->find("META-INF/MANIFEST.MF");
|
||||||
if (region) {
|
if (region) {
|
||||||
unsigned start = 0;
|
unsigned start = 0;
|
||||||
unsigned length;
|
unsigned length;
|
||||||
while (readLine(region->start(), region->length(), &start, &length)) {
|
while (readLine(region->start(), region->length(), &start, &length)) {
|
||||||
|
const unsigned PrefixLength = 12;
|
||||||
if (strncmp("Main-Class: ", reinterpret_cast<const char*>
|
if (strncmp("Main-Class: ", reinterpret_cast<const char*>
|
||||||
(region->start() + start), 12) == 0)
|
(region->start() + start), PrefixLength) == 0)
|
||||||
{
|
{
|
||||||
result = strndup
|
result = static_cast<char*>(malloc(length + 1 - PrefixLength));
|
||||||
(reinterpret_cast<const char*>(region->start() + start + 12),
|
memcpy(result, region->start() + start + PrefixLength,
|
||||||
length - 12);
|
length - PrefixLength);
|
||||||
|
result[length - PrefixLength] = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
start += length;
|
start += length;
|
||||||
|
@ -1,2 +1,20 @@
|
|||||||
#define JNI_OnLoad net_JNI_OnLoad
|
#define JNI_OnLoad net_JNI_OnLoad
|
||||||
#include "net_util.c"
|
#include "net_util.c"
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
|
||||||
|
#undef IN6_SET_ADDR_UNSPECIFIED
|
||||||
|
#define IN6_SET_ADDR_UNSPECIFIED(a) \
|
||||||
|
memset((a)->s6_bytes,0,sizeof(struct in6_addr))
|
||||||
|
|
||||||
|
void
|
||||||
|
IN6ADDR_SETANY(struct sockaddr_in6 *a)
|
||||||
|
{
|
||||||
|
a->sin6_family = AF_INET6;
|
||||||
|
a->sin6_port = 0;
|
||||||
|
a->sin6_flowinfo = 0;
|
||||||
|
IN6_SET_ADDR_UNSPECIFIED(&a->sin6_addr);
|
||||||
|
a->sin6_scope_id = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user