mirror of https://github.com/apache/lucene.git
LUCENE-8982: Separate out native code to another module to allow cpp build with gradle (#2068)
* LUCENE-8982: Separate out native code to another module to allow cpp build with gradle
This commit is contained in:
parent
3ae0ca23d9
commit
ebc87a8a27
|
@ -154,6 +154,9 @@ apply from: file('gradle/generation/snowball.gradle')
|
||||||
apply from: file('gradle/generation/kuromoji.gradle')
|
apply from: file('gradle/generation/kuromoji.gradle')
|
||||||
apply from: file('gradle/generation/nori.gradle')
|
apply from: file('gradle/generation/nori.gradle')
|
||||||
|
|
||||||
|
// Shared configuration of subprojects containing native code.
|
||||||
|
apply from: file('gradle/native/disable-native.gradle')
|
||||||
|
|
||||||
// Additional development aids.
|
// Additional development aids.
|
||||||
apply from: file('gradle/maven/maven-local.gradle')
|
apply from: file('gradle/maven/maven-local.gradle')
|
||||||
apply from: file('gradle/testing/per-project-summary.gradle')
|
apply from: file('gradle/testing/per-project-summary.gradle')
|
||||||
|
|
|
@ -0,0 +1,82 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// This is the master switch to disable all tasks that compile
|
||||||
|
// native (cpp) code.
|
||||||
|
rootProject.ext {
|
||||||
|
buildNative = propertyOrDefault("build.native", true).toBoolean()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Explicitly list all projects that should be configured for native extensions.
|
||||||
|
// We could scan for projects with a the cpp-library plugin but this is faster.
|
||||||
|
def nativeProjects = allprojects.findAll {it.path in [
|
||||||
|
":lucene:misc:native"
|
||||||
|
]}
|
||||||
|
|
||||||
|
def javaProjectsWithNativeDeps = allprojects.findAll {it.path in [
|
||||||
|
":lucene:misc"
|
||||||
|
]}
|
||||||
|
|
||||||
|
// Set up defaults for projects with native dependencies.
|
||||||
|
configure(javaProjectsWithNativeDeps, {
|
||||||
|
configurations {
|
||||||
|
nativeDeps {
|
||||||
|
attributes {
|
||||||
|
attributes.attribute(Usage.USAGE_ATTRIBUTE, objects.named(Usage.class, Usage.NATIVE_RUNTIME))
|
||||||
|
attributes.attribute(CppBinary.OPTIMIZED_ATTRIBUTE, false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
plugins.withType(JavaPlugin) {
|
||||||
|
ext {
|
||||||
|
testOptions += [
|
||||||
|
[propName: 'tests.native', value: buildNative, description: "Enable tests that require native extensions."]
|
||||||
|
]
|
||||||
|
|
||||||
|
nativeDepsDir = file("${buildDir}/nativeDeps")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only copy and attach native deps if native build is enabled.
|
||||||
|
if (buildNative) {
|
||||||
|
task copyNativeDeps(type: Sync) {
|
||||||
|
from configurations.nativeDeps
|
||||||
|
into nativeDepsDir
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.withType(Test) {
|
||||||
|
dependsOn copyNativeDeps
|
||||||
|
systemProperty "java.library.path", nativeDepsDir
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// If native build is disabled we just disable all tasks in the active task set that
|
||||||
|
// originate from "native" projects.
|
||||||
|
//
|
||||||
|
// Perhaps there is a cleaner way to do it but removing their references from
|
||||||
|
// settings.gradle would remove them from IDE detection, dependency resolution, etc.
|
||||||
|
// This way seems better.
|
||||||
|
if (!buildNative) {
|
||||||
|
gradle.taskGraph.whenReady { taskGraph ->
|
||||||
|
def tasks = taskGraph.getAllTasks()
|
||||||
|
tasks.findAll { task -> task.project in nativeProjects }.each { task ->
|
||||||
|
task.enabled = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -62,6 +62,10 @@ grant {
|
||||||
permission java.lang.RuntimePermission "getClassLoader";
|
permission java.lang.RuntimePermission "getClassLoader";
|
||||||
permission java.lang.RuntimePermission "setContextClassLoader";
|
permission java.lang.RuntimePermission "setContextClassLoader";
|
||||||
|
|
||||||
|
// Needed for loading native library (lucene:misc:native) in lucene:misc
|
||||||
|
permission java.lang.RuntimePermission "loadLibrary.LuceneNativeIO";
|
||||||
|
permission java.lang.RuntimePermission "writeFileDescriptor";
|
||||||
|
|
||||||
// TestLockFactoriesMultiJVM opens a random port on 127.0.0.1 (port 0 = ephemeral port range):
|
// TestLockFactoriesMultiJVM opens a random port on 127.0.0.1 (port 0 = ephemeral port range):
|
||||||
permission java.net.SocketPermission "127.0.0.1:0", "accept,listen,resolve";
|
permission java.net.SocketPermission "127.0.0.1:0", "accept,listen,resolve";
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,10 @@ System Requirements
|
||||||
|
|
||||||
API Changes
|
API Changes
|
||||||
|
|
||||||
|
* LUCENE-8982: Separate out native code to another module to allow cpp
|
||||||
|
build with gradle. This also changes the name of the native "posix-support"
|
||||||
|
library to LuceneNativeIO. (Zachary Chen, Dawid Weiss)
|
||||||
|
|
||||||
* LUCENE-9562: All binary analysis packages (and corresponding
|
* LUCENE-9562: All binary analysis packages (and corresponding
|
||||||
Maven artifacts) with names containing '-analyzers-' have been renamed
|
Maven artifacts) with names containing '-analyzers-' have been renamed
|
||||||
to '-analysis-'. (Dawid Weiss)
|
to '-analysis-'. (Dawid Weiss)
|
||||||
|
|
|
@ -22,4 +22,6 @@ description = 'Index tools and other miscellaneous code'
|
||||||
dependencies {
|
dependencies {
|
||||||
api project(':lucene:core')
|
api project(':lucene:core')
|
||||||
testImplementation project(':lucene:test-framework')
|
testImplementation project(':lucene:test-framework')
|
||||||
}
|
|
||||||
|
nativeDeps project(":lucene:misc:native")
|
||||||
|
}
|
|
@ -0,0 +1,69 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This gets separated out from misc module into a native module due to incompatibility between cpp-library and java-library plugins.
|
||||||
|
* For details, please see https://github.com/gradle/gradle-native/issues/352#issuecomment-461724948
|
||||||
|
*/
|
||||||
|
import org.apache.tools.ant.taskdefs.condition.Os
|
||||||
|
|
||||||
|
description = 'Module for native code'
|
||||||
|
|
||||||
|
apply plugin: 'cpp-library'
|
||||||
|
|
||||||
|
library {
|
||||||
|
baseName = 'LuceneNativeIO'
|
||||||
|
|
||||||
|
// Native build for Windows platform will be added in later stage
|
||||||
|
targetMachines = [
|
||||||
|
machines.linux.x86_64,
|
||||||
|
machines.macOS.x86_64,
|
||||||
|
machines.windows.x86_64
|
||||||
|
]
|
||||||
|
|
||||||
|
// Point at platform-specific sources. Other platforms will be ignored
|
||||||
|
// (plugin won't find the toolchain).
|
||||||
|
if (Os.isFamily(Os.FAMILY_WINDOWS)) {
|
||||||
|
source.from file("${projectDir}/src/main/windows")
|
||||||
|
} else if (Os.isFamily(Os.FAMILY_UNIX) || Os.isFamily(Os.FAMILY_MAC)) {
|
||||||
|
source.from file("${projectDir}/src/main/posix")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.withType(CppCompile).configureEach {
|
||||||
|
def javaHome = rootProject.ext.runtimeJava.getInstallationDirectory().getAsFile().getPath()
|
||||||
|
|
||||||
|
// Assume standard openjdk layout. This means only one architecture-specific include folder
|
||||||
|
// is present.
|
||||||
|
systemIncludes.from file("${javaHome}/include")
|
||||||
|
|
||||||
|
for (def path : [
|
||||||
|
file("${javaHome}/include/win32"),
|
||||||
|
file("${javaHome}/include/darwin"),
|
||||||
|
file("${javaHome}/include/linux"),
|
||||||
|
file("${javaHome}/include/solaris")]) {
|
||||||
|
if (path.exists()) {
|
||||||
|
systemIncludes.from path
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
compilerArgs.add '-fPIC'
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.withType(LinkSharedLibrary).configureEach {
|
||||||
|
linkerArgs.add '-lstdc++'
|
||||||
|
}
|
|
@ -38,12 +38,12 @@
|
||||||
|
|
||||||
#ifdef LINUX
|
#ifdef LINUX
|
||||||
/*
|
/*
|
||||||
* Class: org_apache_lucene_store_NativePosixUtil
|
* Class: org_apache_lucene_misc_store_NativePosixUtil
|
||||||
* Method: posix_fadvise
|
* Method: posix_fadvise
|
||||||
* Signature: (Ljava/io/FileDescriptor;JJI)V
|
* Signature: (Ljava/io/FileDescriptor;JJI)V
|
||||||
*/
|
*/
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jint JNICALL Java_org_apache_lucene_store_NativePosixUtil_posix_1fadvise(JNIEnv *env, jclass _ignore, jobject fileDescriptor, jlong offset, jlong len, jint advice)
|
JNIEXPORT jint JNICALL Java_org_apache_lucene_misc_store_NativePosixUtil_posix_1fadvise(JNIEnv *env, jclass _ignore, jobject fileDescriptor, jlong offset, jlong len, jint advice)
|
||||||
{
|
{
|
||||||
jfieldID field_fd;
|
jfieldID field_fd;
|
||||||
jmethodID const_fdesc;
|
jmethodID const_fdesc;
|
||||||
|
@ -103,12 +103,12 @@ JNIEXPORT jint JNICALL Java_org_apache_lucene_store_NativePosixUtil_posix_1fadvi
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_apache_lucene_store_NativePosixUtil
|
* Class: org_apache_lucene_misc_store_NativePosixUtil
|
||||||
* Method: open_direct
|
* Method: open_direct
|
||||||
* Signature: (Ljava/lang/String;Z)Ljava/io/FileDescriptor;
|
* Signature: (Ljava/lang/String;Z)Ljava/io/FileDescriptor;
|
||||||
*/
|
*/
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jobject JNICALL Java_org_apache_lucene_store_NativePosixUtil_open_1direct(JNIEnv *env, jclass _ignore, jstring filename, jboolean readOnly)
|
JNIEXPORT jobject JNICALL Java_org_apache_lucene_misc_store_NativePosixUtil_open_1direct(JNIEnv *env, jclass _ignore, jstring filename, jboolean readOnly)
|
||||||
{
|
{
|
||||||
jfieldID field_fd;
|
jfieldID field_fd;
|
||||||
jmethodID const_fdesc;
|
jmethodID const_fdesc;
|
||||||
|
@ -169,12 +169,12 @@ JNIEXPORT jobject JNICALL Java_org_apache_lucene_store_NativePosixUtil_open_1dir
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_apache_lucene_store_NativePosixUtil
|
* Class: org_apache_lucene_misc_store_NativePosixUtil
|
||||||
* Method: pread
|
* Method: pread
|
||||||
* Signature: (Ljava/io/FileDescriptor;JLjava/nio/ByteBuffer;)I
|
* Signature: (Ljava/io/FileDescriptor;JLjava/nio/ByteBuffer;)I
|
||||||
*/
|
*/
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jlong JNICALL Java_org_apache_lucene_store_NativePosixUtil_pread(JNIEnv *env, jclass _ignore, jobject jfd, jlong pos, jobject byteBuf)
|
JNIEXPORT jlong JNICALL Java_org_apache_lucene_misc_store_NativePosixUtil_pread(JNIEnv *env, jclass _ignore, jobject jfd, jlong pos, jobject byteBuf)
|
||||||
{
|
{
|
||||||
// get int fd:
|
// get int fd:
|
||||||
jclass class_fdesc = env->FindClass("java/io/FileDescriptor");
|
jclass class_fdesc = env->FindClass("java/io/FileDescriptor");
|
||||||
|
@ -214,12 +214,12 @@ JNIEXPORT jlong JNICALL Java_org_apache_lucene_store_NativePosixUtil_pread(JNIEn
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_apache_lucene_store_NativePosixUtil
|
* Class: org_apache_lucene_misc_store_NativePosixUtil
|
||||||
* Method: posix_madvise
|
* Method: posix_madvise
|
||||||
* Signature: (Ljava/nio/ByteBuffer;I)I
|
* Signature: (Ljava/nio/ByteBuffer;I)I
|
||||||
*/
|
*/
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jint JNICALL Java_org_apache_lucene_store_NativePosixUtil_posix_1madvise(JNIEnv *env, jclass _ignore, jobject buffer, jint advice) {
|
JNIEXPORT jint JNICALL Java_org_apache_lucene_misc_store_NativePosixUtil_posix_1madvise(JNIEnv *env, jclass _ignore, jobject buffer, jint advice) {
|
||||||
void *p = env->GetDirectBufferAddress(buffer);
|
void *p = env->GetDirectBufferAddress(buffer);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -280,12 +280,12 @@ JNIEXPORT jint JNICALL Java_org_apache_lucene_store_NativePosixUtil_posix_1madvi
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_apache_lucene_store_NativePosixUtil
|
* Class: org_apache_lucene_misc_store_NativePosixUtil
|
||||||
* Method: madvise
|
* Method: madvise
|
||||||
* Signature: (Ljava/nio/ByteBuffer;I)I
|
* Signature: (Ljava/nio/ByteBuffer;I)I
|
||||||
*/
|
*/
|
||||||
extern "C"
|
extern "C"
|
||||||
JNIEXPORT jint JNICALL Java_org_apache_lucene_store_NativePosixUtil_madvise(JNIEnv *env, jclass _ignore, jobject buffer, jint advice) {
|
JNIEXPORT jint JNICALL Java_org_apache_lucene_misc_store_NativePosixUtil_madvise(JNIEnv *env, jclass _ignore, jobject buffer, jint advice) {
|
||||||
void *p = env->GetDirectBufferAddress(buffer);
|
void *p = env->GetDirectBufferAddress(buffer);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
return -1;
|
return -1;
|
|
@ -56,11 +56,11 @@ void throwException(JNIEnv *env, const char *clazz, const char *msg)
|
||||||
/**
|
/**
|
||||||
* Opens a handle to a file.
|
* Opens a handle to a file.
|
||||||
*
|
*
|
||||||
* Class: org_apache_lucene_store_WindowsDirectory
|
* Class: org_apache_lucene_misc_store_WindowsDirectory
|
||||||
* Method: open
|
* Method: open
|
||||||
* Signature: (Ljava/lang/String;)J
|
* Signature: (Ljava/lang/String;)J
|
||||||
*/
|
*/
|
||||||
JNIEXPORT jlong JNICALL Java_org_apache_lucene_store_WindowsDirectory_open
|
JNIEXPORT jlong JNICALL Java_org_apache_lucene_misc_store_WindowsDirectory_open
|
||||||
(JNIEnv *env, jclass ignored, jstring filename)
|
(JNIEnv *env, jclass ignored, jstring filename)
|
||||||
{
|
{
|
||||||
char *fname;
|
char *fname;
|
||||||
|
@ -95,11 +95,11 @@ JNIEXPORT jlong JNICALL Java_org_apache_lucene_store_WindowsDirectory_open
|
||||||
* Reads data into the byte array, starting at offset, for length characters.
|
* Reads data into the byte array, starting at offset, for length characters.
|
||||||
* The read is positioned at pos.
|
* The read is positioned at pos.
|
||||||
*
|
*
|
||||||
* Class: org_apache_lucene_store_WindowsDirectory
|
* Class: org_apache_lucene_misc_store_WindowsDirectory
|
||||||
* Method: read
|
* Method: read
|
||||||
* Signature: (J[BIIJ)I
|
* Signature: (J[BIIJ)I
|
||||||
*/
|
*/
|
||||||
JNIEXPORT jint JNICALL Java_org_apache_lucene_store_WindowsDirectory_read
|
JNIEXPORT jint JNICALL Java_org_apache_lucene_misc_store_WindowsDirectory_read
|
||||||
(JNIEnv *env, jclass ignored, jlong fd, jbyteArray bytes, jint offset, jint length, jlong pos)
|
(JNIEnv *env, jclass ignored, jlong fd, jbyteArray bytes, jint offset, jint length, jlong pos)
|
||||||
{
|
{
|
||||||
OVERLAPPED io = { 0 };
|
OVERLAPPED io = { 0 };
|
||||||
|
@ -140,11 +140,11 @@ JNIEXPORT jint JNICALL Java_org_apache_lucene_store_WindowsDirectory_read
|
||||||
/**
|
/**
|
||||||
* Closes a handle to a file
|
* Closes a handle to a file
|
||||||
*
|
*
|
||||||
* Class: org_apache_lucene_store_WindowsDirectory
|
* Class: org_apache_lucene_misc_store_WindowsDirectory
|
||||||
* Method: close
|
* Method: close
|
||||||
* Signature: (J)V
|
* Signature: (J)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_apache_lucene_store_WindowsDirectory_close
|
JNIEXPORT void JNICALL Java_org_apache_lucene_misc_store_WindowsDirectory_close
|
||||||
(JNIEnv *env, jclass ignored, jlong fd)
|
(JNIEnv *env, jclass ignored, jlong fd)
|
||||||
{
|
{
|
||||||
if (!CloseHandle((HANDLE) fd)) {
|
if (!CloseHandle((HANDLE) fd)) {
|
||||||
|
@ -155,11 +155,11 @@ JNIEXPORT void JNICALL Java_org_apache_lucene_store_WindowsDirectory_close
|
||||||
/**
|
/**
|
||||||
* Returns the length in bytes of a file.
|
* Returns the length in bytes of a file.
|
||||||
*
|
*
|
||||||
* Class: org_apache_lucene_store_WindowsDirectory
|
* Class: org_apache_lucene_misc_store_WindowsDirectory
|
||||||
* Method: length
|
* Method: length
|
||||||
* Signature: (J)J
|
* Signature: (J)J
|
||||||
*/
|
*/
|
||||||
JNIEXPORT jlong JNICALL Java_org_apache_lucene_store_WindowsDirectory_length
|
JNIEXPORT jlong JNICALL Java_org_apache_lucene_misc_store_WindowsDirectory_length
|
||||||
(JNIEnv *env, jclass ignored, jlong fd)
|
(JNIEnv *env, jclass ignored, jlong fd)
|
||||||
{
|
{
|
||||||
BY_HANDLE_FILE_INFORMATION info;
|
BY_HANDLE_FILE_INFORMATION info;
|
|
@ -33,7 +33,7 @@ public final class NativePosixUtil {
|
||||||
public final static int NOREUSE = 5;
|
public final static int NOREUSE = 5;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
System.loadLibrary("NativePosixUtil");
|
System.loadLibrary("LuceneNativeIO");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native int posix_fadvise(FileDescriptor fd, long offset, long len, int advise) throws IOException;
|
private static native int posix_fadvise(FileDescriptor fd, long offset, long len, int advise) throws IOException;
|
||||||
|
|
|
@ -56,10 +56,9 @@ import org.apache.lucene.util.SuppressForbidden;
|
||||||
*
|
*
|
||||||
* <p>To use this you must compile
|
* <p>To use this you must compile
|
||||||
* NativePosixUtil.cpp (exposes Linux-specific APIs through
|
* NativePosixUtil.cpp (exposes Linux-specific APIs through
|
||||||
* JNI) for your platform, by running <code>ant
|
* JNI) for your platform, by running <code>./gradlew build</code>, and then putting the resulting
|
||||||
* build-native-unix</code>, and then putting the resulting
|
* <code>libLuceneNativeIO.so</code> or <code>libLuceneNativeIO.dylib</code>
|
||||||
* <code>libNativePosixUtil.so</code> (from
|
* (from <code>lucene/misc/native/build/lib/release/platform/</code>) onto your dynamic
|
||||||
* <code>lucene/build/native</code>) onto your dynamic
|
|
||||||
* linker search path.
|
* linker search path.
|
||||||
*
|
*
|
||||||
* <p><b>WARNING</b>: this code is very new and quite easily
|
* <p><b>WARNING</b>: this code is very new and quite easily
|
||||||
|
|
|
@ -34,14 +34,10 @@ import java.nio.file.Path;
|
||||||
* <p>
|
* <p>
|
||||||
* Steps:
|
* Steps:
|
||||||
* <ol>
|
* <ol>
|
||||||
* <li>Compile the source code to create WindowsDirectory.dll:
|
* <li>Compile the source code to create libLuceneNativeIO.dll: <code>./gradlew build</code>
|
||||||
* <blockquote>
|
* <li>Put the resulting <code>libLuceneNativeIO.dll</code>
|
||||||
* c:\mingw\bin\g++ -Wall -D_JNI_IMPLEMENTATION_ -Wl,--kill-at
|
* (from <code>lucene/misc/native/build/lib/release/platform/</code>)
|
||||||
* -I"%JAVA_HOME%\include" -I"%JAVA_HOME%\include\win32" -static-libgcc
|
* into some directory in your windows PATH
|
||||||
* -static-libstdc++ -shared WindowsDirectory.cpp -o WindowsDirectory.dll
|
|
||||||
* </blockquote>
|
|
||||||
* For 64-bit JREs, use mingw64, with the -m64 option.
|
|
||||||
* <li>Put WindowsDirectory.dll into some directory in your windows PATH
|
|
||||||
* <li>Open indexes with WindowsDirectory and use it.
|
* <li>Open indexes with WindowsDirectory and use it.
|
||||||
* </ol>
|
* </ol>
|
||||||
* @lucene.experimental
|
* @lucene.experimental
|
||||||
|
@ -50,7 +46,7 @@ public class WindowsDirectory extends FSDirectory {
|
||||||
private static final int DEFAULT_BUFFERSIZE = 4096; /* default pgsize on ia32/amd64 */
|
private static final int DEFAULT_BUFFERSIZE = 4096; /* default pgsize on ia32/amd64 */
|
||||||
|
|
||||||
static {
|
static {
|
||||||
System.loadLibrary("WindowsDirectory");
|
System.loadLibrary("LuceneNativeIO");
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Create a new WindowsDirectory for the named location.
|
/** Create a new WindowsDirectory for the named location.
|
||||||
|
|
|
@ -42,26 +42,25 @@ used during merging of segments larger than a specified size (default
|
||||||
searching, keeping search more responsive while large merges run.
|
searching, keeping search more responsive while large merges run.
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
See <a target=_top href="http://blog.mikemccandless.com/2010/06/lucene-and-fadvisemadvise.html">this blog post</a>
|
See <a target="_top" href="http://blog.mikemccandless.com/2010/06/lucene-and-fadvisemadvise.html">this blog post</a>
|
||||||
for details.
|
for details.
|
||||||
|
|
||||||
Steps to build:
|
<p>Steps to build (from the project's root directory):
|
||||||
<ul>
|
<ul>
|
||||||
<li> <code>cd lucene/misc/</code>
|
<li>Compile both the native library part (<code>libLuceneNativeIO</code>) and Java sources with:
|
||||||
|
<code>./gradlew -p lucene/misc build</code>.</li>
|
||||||
<li> To compile NativePosixUtil.cpp -> libNativePosixUtil.so, run<code> ant build-native-unix</code>.
|
|
||||||
|
|
||||||
<li><code>libNativePosixUtil.so</code> will be located in the <code>lucene/build/native/</code> folder
|
<li>The native library will be located in the <code>lucene/misc/native/build/lib/main/release/<i>your-platform</i></code> folder.</li>
|
||||||
|
|
||||||
<li> Make sure libNativePosixUtil.so is on your LD_LIBRARY_PATH so java can find it (something like <code>export LD_LIBRARY_PATH=/path/to/dir:$LD_LIBRARY_PATH</code>, where /path/to/dir contains libNativePosixUtil.so)
|
<li>On Unix-ish systems, make sure <code>libNativePosixUtil.so</code> is on your
|
||||||
|
<code>LD_LIBRARY_PATH</code> so java can find it (something like <code>export LD_LIBRARY_PATH=/path/to/dir:$LD_LIBRARY_PATH</code>,
|
||||||
<li> <code>ant jar</code> to compile the java source and put that JAR on your CLASSPATH
|
where /path/to/dir contains <code>libLuceneNativeIO.so</code>).</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
NativePosixUtil.cpp/java also expose access to the posix_madvise,
|
The native library exposes access to the <code>posix_madvise</code>,
|
||||||
madvise, posix_fadvise functions, which are somewhat more cross
|
<code>madvise</code>, <code>posix_fadvise</code> functions, which are somewhat more cross
|
||||||
platform than O_DIRECT, however, in testing (see above link), these
|
platform than <code>O_DIRECT</code>, however, in testing (see above link), these
|
||||||
APIs did not seem to help prevent buffer cache eviction.
|
APIs did not seem to help prevent buffer cache eviction.
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.misc.store;
|
||||||
|
|
||||||
|
import com.carrotsearch.randomizedtesting.rules.TestRuleAdapter;
|
||||||
|
import org.apache.lucene.util.Constants;
|
||||||
|
import org.junit.Assume;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public class NativeLibEnableRule extends TestRuleAdapter {
|
||||||
|
enum OperatingSystem {
|
||||||
|
LINUX(Constants.LINUX),
|
||||||
|
WINDOWS(Constants.WINDOWS),
|
||||||
|
SUN_OS(Constants.SUN_OS),
|
||||||
|
MAC(Constants.MAC_OS_X),
|
||||||
|
FREE_BSD(Constants.FREE_BSD);
|
||||||
|
|
||||||
|
public final boolean enabled;
|
||||||
|
|
||||||
|
OperatingSystem(boolean enabled) {
|
||||||
|
this.enabled = enabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private final Set<OperatingSystem> runOn;
|
||||||
|
|
||||||
|
public NativeLibEnableRule(Set<OperatingSystem> runOn) {
|
||||||
|
this.runOn = runOn;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void before() {
|
||||||
|
Assume.assumeTrue("Test ignored (tests.native is false)",
|
||||||
|
Boolean.parseBoolean(System.getProperty("tests.native", "false")));
|
||||||
|
|
||||||
|
Assume.assumeTrue("Test ignored, only applies to architectures: " + runOn,
|
||||||
|
runOn.stream().anyMatch(os -> os.enabled));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.misc.store;
|
||||||
|
|
||||||
|
import com.carrotsearch.randomizedtesting.LifecycleScope;
|
||||||
|
import com.carrotsearch.randomizedtesting.RandomizedTest;
|
||||||
|
import org.apache.lucene.store.ByteBuffersDirectory;
|
||||||
|
import org.apache.lucene.store.Directory;
|
||||||
|
import org.apache.lucene.store.IOContext;
|
||||||
|
import org.apache.lucene.store.MergeInfo;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class NativeUnixDirectoryTest extends LuceneTestCase {
|
||||||
|
@Rule
|
||||||
|
public static TestRule requiresNative = new NativeLibEnableRule(
|
||||||
|
EnumSet.of(NativeLibEnableRule.OperatingSystem.MAC,
|
||||||
|
NativeLibEnableRule.OperatingSystem.FREE_BSD,
|
||||||
|
NativeLibEnableRule.OperatingSystem.LINUX));
|
||||||
|
|
||||||
|
public void testLibraryLoaded() throws IOException {
|
||||||
|
try (ByteBuffersDirectory ramDir = new ByteBuffersDirectory();
|
||||||
|
Directory dir = new NativeUnixDirectory(RandomizedTest.newTempDir(LifecycleScope.TEST), ramDir)) {
|
||||||
|
MergeInfo mergeInfo = new MergeInfo(1000, Integer.MAX_VALUE, true, 1);
|
||||||
|
dir.createOutput("test", new IOContext(mergeInfo)).close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.misc.store;
|
||||||
|
|
||||||
|
import com.carrotsearch.randomizedtesting.LifecycleScope;
|
||||||
|
import com.carrotsearch.randomizedtesting.RandomizedTest;
|
||||||
|
import org.apache.lucene.store.Directory;
|
||||||
|
import org.apache.lucene.store.IOContext;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.rules.TestRule;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class WindowsDirectoryTest extends LuceneTestCase {
|
||||||
|
@Rule
|
||||||
|
public static TestRule requiresNative = new NativeLibEnableRule(
|
||||||
|
EnumSet.of(NativeLibEnableRule.OperatingSystem.WINDOWS));
|
||||||
|
|
||||||
|
public void testLibraryLoaded() throws IOException {
|
||||||
|
try (Directory dir = new WindowsDirectory(RandomizedTest.newTempDir(LifecycleScope.TEST))) {
|
||||||
|
dir.createOutput("test", IOContext.DEFAULT).close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -32,7 +32,9 @@ def includeInBinaries = project(":lucene").subprojects.findAll {subproject ->
|
||||||
":lucene:packaging",
|
":lucene:packaging",
|
||||||
":lucene:documentation",
|
":lucene:documentation",
|
||||||
// Exclude parent container project of analysis modules (no artifacts).
|
// Exclude parent container project of analysis modules (no artifacts).
|
||||||
":lucene:analysis"
|
":lucene:analysis",
|
||||||
|
// Exclude native module, which requires manual copying and enabling
|
||||||
|
":lucene:misc:native"
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,6 +42,7 @@ include "lucene:join"
|
||||||
include "lucene:luke"
|
include "lucene:luke"
|
||||||
include "lucene:memory"
|
include "lucene:memory"
|
||||||
include "lucene:misc"
|
include "lucene:misc"
|
||||||
|
include "lucene:misc:native"
|
||||||
include "lucene:monitor"
|
include "lucene:monitor"
|
||||||
include "lucene:queries"
|
include "lucene:queries"
|
||||||
include "lucene:queryparser"
|
include "lucene:queryparser"
|
||||||
|
@ -73,4 +74,4 @@ include "solr:example"
|
||||||
include "solr:documentation"
|
include "solr:documentation"
|
||||||
include "solr:packaging"
|
include "solr:packaging"
|
||||||
include "solr:docker"
|
include "solr:docker"
|
||||||
include "solr:docker:package"
|
include "solr:docker:package"
|
||||||
|
|
Loading…
Reference in New Issue