summaryrefslogtreecommitdiff
path: root/jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx')
-rw-r--r--jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx287
1 files changed, 287 insertions, 0 deletions
diff --git a/jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx b/jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx
new file mode 100644
index 000000000000..41ba8b2e27a8
--- /dev/null
+++ b/jvmfwk/plugins/sunmajor/pluginlib/gnujre.cxx
@@ -0,0 +1,287 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_jvmfwk.hxx"
+
+#include "osl/file.hxx"
+#include "osl/thread.h"
+#include "gnujre.hxx"
+#include "util.hxx"
+
+using namespace rtl;
+using namespace std;
+using namespace osl;
+
+namespace jfw_plugin
+{
+
+Reference<VendorBase> GnuInfo::createInstance()
+{
+ return new GnuInfo;
+}
+
+char const* const* GnuInfo::getJavaExePaths(int * size)
+{
+ static char const * ar[] = {
+ "gij",
+ "bin/gij",
+ };
+ *size = sizeof (ar) / sizeof (char*);
+ return ar;
+}
+
+#if defined(MIPS) && defined(OSL_LITENDIAN)
+#define GCJ_JFW_PLUGIN_ARCH "mipsel"
+#else
+#define GCJ_JFW_PLUGIN_ARCH JFW_PLUGIN_ARCH
+#endif
+
+char const* const* GnuInfo::getRuntimePaths(int * size)
+{
+ static char const* ar[]= {
+ "/libjvm.so",
+ "/lib/" GCJ_JFW_PLUGIN_ARCH "/client/libjvm.so",
+ "/gcj-4.1.1/libjvm.so",
+ "/libgcj.so.7",
+ "/libgcj.so.6"
+ };
+ *size = sizeof(ar) / sizeof (char*);
+ return ar;
+}
+
+bool GnuInfo::initialize(vector<pair<OUString, OUString> > props)
+{
+ //get java.vendor, java.version, java.home,
+ //javax.accessibility.assistive_technologies from system properties
+
+ OUString sVendor;
+ OUString sJavaLibraryPath;
+ typedef vector<pair<OUString, OUString> >::const_iterator it_prop;
+ OUString sVendorProperty(
+ RTL_CONSTASCII_USTRINGPARAM("java.vendor"));
+ OUString sVersionProperty(
+ RTL_CONSTASCII_USTRINGPARAM("java.version"));
+ OUString sJavaHomeProperty(
+ RTL_CONSTASCII_USTRINGPARAM("java.home"));
+ OUString sJavaLibraryPathProperty(
+ RTL_CONSTASCII_USTRINGPARAM("java.library.path"));
+ OUString sGNUHomeProperty(
+ RTL_CONSTASCII_USTRINGPARAM("gnu.classpath.home.url"));
+ OUString sAccessProperty(
+ RTL_CONSTASCII_USTRINGPARAM("javax.accessibility.assistive_technologies"));
+
+ bool bVersion = false;
+ bool bVendor = false;
+ bool bHome = false;
+ bool bJavaHome = false;
+ bool bJavaLibraryPath = false;
+ bool bAccess = false;
+
+ typedef vector<pair<OUString, OUString> >::const_iterator it_prop;
+ for (it_prop i = props.begin(); i != props.end(); i++)
+ {
+ if(! bVendor && sVendorProperty.equals(i->first))
+ {
+ m_sVendor = i->second;
+ bVendor = true;
+ }
+ else if (!bVersion && sVersionProperty.equals(i->first))
+ {
+ m_sVersion = i->second;
+ bVersion = true;
+ }
+ else if (!bHome && sGNUHomeProperty.equals(i->first))
+ {
+ m_sHome = i->second;
+ bHome = true;
+ }
+ else if (!bJavaHome && sJavaHomeProperty.equals(i->first))
+ {
+ OUString fileURL;
+ if (osl_getFileURLFromSystemPath(i->second.pData,& fileURL.pData) ==
+ osl_File_E_None)
+ {
+ //make sure that the drive letter have all the same case
+ //otherwise file:///c:/jre and file:///C:/jre produce two
+ //different objects!!!
+ if (makeDriveLetterSame( & fileURL))
+ {
+ m_sJavaHome = fileURL;
+ bJavaHome = true;
+ }
+ }
+ }
+ else if (!bJavaLibraryPath && sJavaLibraryPathProperty.equals(i->first))
+ {
+ sal_Int32 nIndex = 0;
+ osl_getFileURLFromSystemPath(i->second.getToken(0, ':', nIndex).pData, &sJavaLibraryPath.pData);
+ bJavaLibraryPath = true;
+ }
+ else if (!bAccess && sAccessProperty.equals(i->first))
+ {
+ if (i->second.getLength() > 0)
+ {
+ m_bAccessibility = true;
+ bAccess = true;
+ }
+ }
+ // the javax.accessibility.xxx property may not be set. Therefore we
+ //must search through all properties.
+
+ }
+ if (!bVersion || !bVendor || !bHome)
+ return false;
+
+ if (!m_sJavaHome.getLength())
+ m_sJavaHome = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("file:///usr/lib"));
+
+ // init m_sRuntimeLibrary
+ OSL_ASSERT(m_sHome.getLength());
+ //call virtual function to get the possible paths to the runtime library.
+
+ int size = 0;
+ char const* const* arRtPaths = getRuntimePaths( & size);
+ vector<OUString> libpaths = getVectorFromCharArray(arRtPaths, size);
+
+ bool bRt = false;
+ typedef vector<OUString>::const_iterator i_path;
+ for(i_path ip = libpaths.begin(); ip != libpaths.end(); ip++)
+ {
+ //Construct an absolute path to the possible runtime
+ OUString usRt= m_sHome + *ip;
+ DirectoryItem item;
+ if(DirectoryItem::get(usRt, item) == File::E_None)
+ {
+ //found runtime lib
+ m_sRuntimeLibrary = usRt;
+ bRt = true;
+ break;
+ }
+ }
+
+ if (!bRt)
+ {
+ m_sHome = m_sJavaHome;
+ for(i_path ip = libpaths.begin(); ip != libpaths.end(); ip++)
+ {
+ //Construct an absolute path to the possible runtime
+ OUString usRt= m_sHome + *ip;
+ DirectoryItem item;
+ if(DirectoryItem::get(usRt, item) == File::E_None)
+ {
+ //found runtime lib
+ m_sRuntimeLibrary = usRt;
+ bRt = true;
+ break;
+ }
+ }
+ }
+
+ // try to find it by the java.library.path property
+ if (!bRt && m_sJavaHome != sJavaLibraryPath)
+ {
+ m_sHome = sJavaLibraryPath;
+ for(i_path ip = libpaths.begin(); ip != libpaths.end(); ip++)
+ {
+ //Construct an absolute path to the possible runtime
+ OUString usRt= m_sHome + *ip;
+ DirectoryItem item;
+ if(DirectoryItem::get(usRt, item) == File::E_None)
+ {
+ //found runtime lib
+ m_sRuntimeLibrary = usRt;
+ bRt = true;
+ break;
+ }
+ }
+ }
+
+#ifdef X86_64
+ //Make one last final legacy attempt on x86_64 in case the distro placed it in lib64 instead
+ if (!bRt && m_sJavaHome != rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("file:///usr/lib")))
+ {
+ m_sHome = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("file:///usr/lib64"));
+ for(i_path ip = libpaths.begin(); ip != libpaths.end(); ip++)
+ {
+ //Construct an absolute path to the possible runtime
+ OUString usRt= m_sHome + *ip;
+ DirectoryItem item;
+ if(DirectoryItem::get(usRt, item) == File::E_None)
+ {
+ //found runtime lib
+ m_sRuntimeLibrary = usRt;
+ bRt = true;
+ break;
+ }
+ }
+ }
+#endif
+
+ if (!bRt)
+ return false;
+
+ // init m_sLD_LIBRARY_PATH
+ OSL_ASSERT(m_sHome.getLength());
+ size = 0;
+ char const * const * arLDPaths = getLibraryPaths( & size);
+ vector<OUString> ld_paths = getVectorFromCharArray(arLDPaths, size);
+
+ char arSep[]= {SAL_PATHSEPARATOR, 0};
+ OUString sPathSep= OUString::createFromAscii(arSep);
+ bool bLdPath = true;
+ int c = 0;
+ for(i_path il = ld_paths.begin(); il != ld_paths.end(); il ++, c++)
+ {
+ OUString usAbsUrl= m_sHome + *il;
+ // convert to system path
+ OUString usSysPath;
+ if(File::getSystemPathFromFileURL(usAbsUrl, usSysPath) == File::E_None)
+ {
+
+ if(c > 0)
+ m_sLD_LIBRARY_PATH+= sPathSep;
+ m_sLD_LIBRARY_PATH+= usSysPath;
+ }
+ else
+ {
+ bLdPath = false;
+ break;
+ }
+ }
+ if (bLdPath == false)
+ return false;
+
+ return true;
+}
+
+int GnuInfo::compareVersions(const rtl::OUString&) const
+{
+ return 0;
+}
+
+}