summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Modules/CMakeDetermineJavaCompiler.cmake75
-rw-r--r--Modules/CMakeJavaCompiler.cmake.in62
-rw-r--r--Source/cmGlobalGenerator.cxx34
3 files changed, 165 insertions, 6 deletions
diff --git a/Modules/CMakeDetermineJavaCompiler.cmake b/Modules/CMakeDetermineJavaCompiler.cmake
new file mode 100644
index 0000000000..d1034aafb0
--- /dev/null
+++ b/Modules/CMakeDetermineJavaCompiler.cmake
@@ -0,0 +1,75 @@
+# determine the compiler to use for Java programs
+# NOTE, a generator may set CMAKE_JAVA_COMPILER before
+# loading this file to force a compiler.
+
+IF(NOT CMAKE_JAVA_COMPILER)
+ # prefer the environment variable CC
+ IF($ENV{JAVA_COMPILER} MATCHES ".+")
+ GET_FILENAME_COMPONENT(CMAKE_JAVA_COMPILER_INIT $ENV{JAVA_COMPILER} PROGRAM PROGRAM_ARGS CMAKE_JAVA_FLAGS_ENV_INIT)
+ IF(EXISTS ${CMAKE_JAVA_COMPILER_INIT})
+ ELSE(EXISTS ${CMAKE_JAVA_COMPILER_INIT})
+ MESSAGE(SEND_ERROR "Could not find compiler set in environment variable JAVA_COMPILER:\n$ENV{JAVA_COMPILER}.")
+ ENDIF(EXISTS ${CMAKE_JAVA_COMPILER_INIT})
+ ENDIF($ENV{JAVA_COMPILER} MATCHES ".+")
+
+ IF($ENV{JAVA_RUNTIME} MATCHES ".+")
+ GET_FILENAME_COMPONENT(CMAKE_JAVA_RUNTIME_INIT $ENV{JAVA_RUNTIME} PROGRAM PROGRAM_ARGS CMAKE_JAVA_FLAGS_ENV_INIT)
+ IF(EXISTS ${CMAKE_JAVA_RUNTIME_INIT})
+ ELSE(EXISTS ${CMAKE_JAVA_RUNTIME_INIT})
+ MESSAGE(SEND_ERROR "Could not find compiler set in environment variable JAVA_RUNTIME:\n$ENV{JAVA_RUNTIME}.")
+ ENDIF(EXISTS ${CMAKE_JAVA_RUNTIME_INIT})
+ ENDIF($ENV{JAVA_RUNTIME} MATCHES ".+")
+
+ IF($ENV{JAVA_ARCHIVE} MATCHES ".+")
+ GET_FILENAME_COMPONENT(CMAKE_JAVA_ARCHIVE_INIT $ENV{JAVA_ARCHIVE} PROGRAM PROGRAM_ARGS CMAKE_JAVA_FLAGS_ENV_INIT)
+ IF(EXISTS ${CMAKE_JAVA_ARCHIVE_INIT})
+ ELSE(EXISTS ${CMAKE_JAVA_ARCHIVE_INIT})
+ MESSAGE(SEND_ERROR "Could not find compiler set in environment variable JAVA_ARCHIVE:\n$ENV{JAVA_ARCHIVE}.")
+ ENDIF(EXISTS ${CMAKE_JAVA_ARCHIVE_INIT})
+ ENDIF($ENV{JAVA_ARCHIVE} MATCHES ".+")
+
+ SET(JAVA_BIN_PATH
+ /usr/bin
+ /usr/lib/java/bin
+ /usr/share/java/bin
+ /usr/local/bin
+ /usr/local/java/bin
+ "[HKEY_LOCAL_MACHINE\\SOFTWARE\\JavaSoft\\Java Development Kit\\1.4;JavaHome]/bin"
+ "[HKEY_LOCAL_MACHINE\\SOFTWARE\\JavaSoft\\Java Development Kit\\1.3;JavaHome]/bin"
+ )
+ # if no compiler has been specified yet, then look for one
+ IF(CMAKE_JAVA_COMPILER_INIT)
+ SET(CMAKE_JAVA_COMPILER ${CMAKE_JAVA_COMPILER_INIT} CACHE PATH "Java Compiler")
+ ELSE(CMAKE_JAVA_COMPILER_INIT)
+ FIND_PROGRAM(CMAKE_JAVA_COMPILER
+ NAMES javac
+ PATHS ${JAVA_BIN_PATH}
+ )
+ ENDIF(CMAKE_JAVA_COMPILER_INIT)
+
+ # if no runtime has been specified yet, then look for one
+ IF(CMAKE_JAVA_RUNTIME_INIT)
+ SET(CMAKE_JAVA_RUNTIME ${CMAKE_JAVA_RUNTIME_INIT} CACHE PATH "Java Compiler")
+ ELSE(CMAKE_JAVA_RUNTIME_INIT)
+ FIND_PROGRAM(CMAKE_JAVA_RUNTIME
+ NAMES java
+ PATHS ${JAVA_BIN_PATH}
+ )
+ ENDIF(CMAKE_JAVA_RUNTIME_INIT)
+
+ # if no archive has been specified yet, then look for one
+ IF(CMAKE_JAVA_ARCHIVE_INIT)
+ SET(CMAKE_JAVA_ARCHIVE ${CMAKE_JAVA_ARCHIVE_INIT} CACHE PATH "Java Compiler")
+ ELSE(CMAKE_JAVA_ARCHIVE_INIT)
+ FIND_PROGRAM(CMAKE_JAVA_ARCHIVE
+ NAMES jar
+ PATHS ${JAVA_BIN_PATH}
+ )
+ ENDIF(CMAKE_JAVA_ARCHIVE_INIT)
+ENDIF(NOT CMAKE_JAVA_COMPILER)
+MARK_AS_ADVANCED(CMAKE_JAVA_COMPILER)
+
+# configure variables set in this file for fast reload later on
+CONFIGURE_FILE(${CMAKE_ROOT}/Modules/CMakeJavaCompiler.cmake.in
+ ${PROJECT_BINARY_DIR}/CMakeJavaCompiler.cmake IMMEDIATE @ONLY)
+MARK_AS_ADVANCED(CMAKE_AR CMAKE_JAVA_COMPILER_FULLPATH)
diff --git a/Modules/CMakeJavaCompiler.cmake.in b/Modules/CMakeJavaCompiler.cmake.in
new file mode 100644
index 0000000000..c018c5005f
--- /dev/null
+++ b/Modules/CMakeJavaCompiler.cmake.in
@@ -0,0 +1,62 @@
+SET(CMAKE_JAVA_COMPILER "@CMAKE_JAVA_COMPILER@")
+SET(CMAKE_JAVA_RUNTIME "@CMAKE_JAVA_RUNTIME@")
+SET(CMAKE_JAVA_ARCHIVE "@CMAKE_JAVA_ARCHIVE@")
+SET(CMAKE_JAVA_COMPILER_LOADED 1)
+SET(CMAKE_JAVA_RUNTIME_LOADED 1)
+SET(CMAKE_JAVA_ARCHIVE_LOADED 1)
+
+MACRO(ADD_JAVA_LIBRARY LIBRARYNAME SOURCES)
+ SET(CMAKE_JAVA_INCLUDE_PATH ${CMAKE_JAVA_INCLUDE_PATH}
+ ${CMAKE_CURRENT_SOURCE_DIR}
+ ${CMAKE_CURRENT_BINARY_DIR}
+ ${LIBRARY_OUTPUT_PATH})
+ SET(CMAKE_JAVA_INCLUDE_PATH_TOTAL "")
+
+ FOREACH(DIR ${CMAKE_JAVA_INCLUDE_PATH})
+ SET(CMAKE_JAVA_INCLUDE_PATH_TOTAL "${CMAKE_JAVA_INCLUDE_PATH_TOTAL}:${DIR}")
+ ENDFOREACH(DIR)
+ IF(WIN32)
+ STRING(REGEX REPLACE "/" "\\\\" CMAKE_JAVA_INCLUDE_PATH_TOTAL
+ ${CMAKE_JAVA_INCLUDE_PATH_TOTAL})
+ STRING(REGEX REPLACE "/" "\\\\" CMAKE_JAVA_CLASS_OUTPUT_PATH
+ ${CMAKE_CURRENT_BINARY_DIR})
+ STRING(REGEX REPLACE ":([^\\/])" "\\\\;\\1" CMAKE_JAVA_INCLUDE_PATH_TOTAL
+ ${CMAKE_JAVA_INCLUDE_PATH_TOTAL})
+ ELSE(WIN32)
+ SET(CMAKE_JAVA_CLASS_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR})
+ ENDIF(WIN32)
+
+ ADD_CUSTOM_TARGET(${LIBRARYNAME}_target ALL)
+
+ SET(CMAKE_JAVA_ALL_CLASS_FILES "")
+ FOREACH(SOURCE ${SOURCES})
+ GET_FILENAME_COMPONENT(CLASS_FILE ${SOURCE} NAME_WE)
+ ADD_CUSTOM_COMMAND(SOURCE ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}
+ COMMAND ${CMAKE_JAVA_COMPILER}
+ ARGS ${CMAKE_JAVA_COMPILE_FLAGS}
+ -classpath ${CMAKE_JAVA_INCLUDE_PATH_TOTAL}
+ ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}
+ -d ${CMAKE_JAVA_CLASS_OUTPUT_PATH}/
+ TARGET ${LIBRARYNAME}_target
+ OUTPUTS ${CLASS_FILE}.class
+ COMMENT "Java File" )
+ SET(CMAKE_JAVA_ALL_CLASS_FILES ${CMAKE_JAVA_ALL_CLASS_FILES} ${CLASS_FILE}.class)
+ ENDFOREACH(SOURCE)
+ IF(LIBRARY_OUTPUT_PATH)
+ SET(CMAKE_JAVA_LIBRARY_OUTPUT_PATH ${LIBRARY_OUTPUT_PATH})
+ ELSE(LIBRARY_OUTPUT_PATH)
+ SET(CMAKE_JAVA_LIBRARY_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR})
+ ENDIF(LIBRARY_OUTPUT_PATH)
+ ADD_CUSTOM_COMMAND(SOURCE ${CMAKE_JAVA_ALL_CLASS_FILES}
+ COMMAND ${CMAKE_COMMAND}
+ ARGS -E chdir ${CMAKE_CURRENT_BINARY_DIR}
+ ${CMAKE_JAVA_ARCHIVE}
+ -cvf ${CMAKE_JAVA_LIBRARY_OUTPUT_PATH}/${LIBRARYNAME}.jar *.class
+ TARGET ${LIBRARYNAME}_target
+ DEPENDS ${CMAKE_JAVA_ALL_CLASS_FILES}
+ OUTPUTS ${CMAKE_JAVA_LIBRARY_OUTPUT_PATH}/${LIBRARYNAME}.jar
+ COMMENT "Java Archive")
+ ADD_CUSTOM_COMMAND(SOURCE ${LIBRARYNAME}_target
+ TARGET ${LIBRARYNAME}_target
+ DEPENDS ${CMAKE_JAVA_LIBRARY_OUTPUT_PATH}/${LIBRARYNAME}.jar)
+ENDMACRO(ADD_JAVA_LIBRARY LIBRARYNAME SOURCES) \ No newline at end of file
diff --git a/Source/cmGlobalGenerator.cxx b/Source/cmGlobalGenerator.cxx
index 3edb0d1c3d..e0edfed908 100644
--- a/Source/cmGlobalGenerator.cxx
+++ b/Source/cmGlobalGenerator.cxx
@@ -81,6 +81,16 @@ void cmGlobalGenerator::EnableLanguage(const char* lang,
}
bool needCBackwards = false;
bool needCXXBackwards = false;
+
+ if (!isLocal &&
+ !this->GetLanguageEnabled("C") && !this->GetLanguageEnabled("CXX") &&
+ !this->GetLanguageEnabled("JAVA"))
+ {
+ // Read the DetermineSystem file
+ std::string systemFile = root;
+ systemFile += "/Modules/CMakeDetermineSystem.cmake";
+ mf->ReadListFile(0, systemFile.c_str());
+ }
// check for a C compiler and configure it
if(!isLocal &&
@@ -95,10 +105,6 @@ void cmGlobalGenerator::EnableLanguage(const char* lang,
"CMake");
}
needCBackwards = true;
- // Read the DetermineSystem file
- std::string systemFile = root;
- systemFile += "/Modules/CMakeDetermineSystem.cmake";
- mf->ReadListFile(0, systemFile.c_str());
// read determine C compiler
std::string determineCFile = root;
determineCFile += "/Modules/CMakeDetermineCCompiler.cmake";
@@ -142,7 +148,17 @@ void cmGlobalGenerator::EnableLanguage(const char* lang,
}
}
-
+ // check for a Java compiler and configure it
+ if(!isLocal &&
+ !this->GetLanguageEnabled("JAVA") &&
+ strcmp(lang, "JAVA") == 0)
+ {
+ std::string determineCFile = root;
+ determineCFile += "/Modules/CMakeDetermineJavaCompiler.cmake";
+ mf->ReadListFile(0,determineCFile.c_str());
+ this->SetLanguageEnabled("JAVA");
+ }
+
std::string fpath = rootBin;
if(!mf->GetDefinition("CMAKE_SYSTEM_LOADED"))
{
@@ -162,7 +178,13 @@ void cmGlobalGenerator::EnableLanguage(const char* lang,
fpath += "/CMakeCXXCompiler.cmake";
mf->ReadListFile(0,fpath.c_str());
}
- if(!mf->GetDefinition("CMAKE_SYSTEM_SPECIFIC_INFORMATION_LOADED"))
+ if(strcmp(lang, "JAVA") == 0 && !mf->GetDefinition("CMAKE_JAVA_COMPILER_LOADED"))
+ {
+ fpath = rootBin;
+ fpath += "/CMakeJavaCompiler.cmake";
+ mf->ReadListFile(0,fpath.c_str());
+ }
+ if ( lang[0] == 'C' && !mf->GetDefinition("CMAKE_SYSTEM_SPECIFIC_INFORMATION_LOADED"))
{
fpath = root;
fpath += "/Modules/CMakeSystemSpecificInformation.cmake";