license: STLPort is not included in LibreOffice
[LibreOffice.git] / jvmfwk / inc / vendorbase.hxx
blob02684a62b6757e4a3b026925f72cf1fa67440e0e
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_JVMFWK_PLUGINS_SUNMAJOR_PLUGINLIB_VENDORBASE_HXX
21 #define INCLUDED_JVMFWK_PLUGINS_SUNMAJOR_PLUGINLIB_VENDORBASE_HXX
23 #include <config_java.h>
25 #include <rtl/ustring.hxx>
26 #include <rtl/ref.hxx>
27 #include <osl/endian.h>
28 #include <salhelper/simplereferenceobject.hxx>
29 #include <vector>
31 namespace jfw_plugin
35 //Used by subclasses of VendorBase to build paths to Java runtime
36 #if defined(JAVA_ARCH)
37 #define JFW_PLUGIN_ARCH JAVA_ARCH
38 #elif defined SPARC64
39 #define JFW_PLUGIN_ARCH "sparcv9"
40 #elif defined SPARC
41 #define JFW_PLUGIN_ARCH "sparc"
42 #elif defined X86_64
43 #define JFW_PLUGIN_ARCH "amd64"
44 #elif defined INTEL
45 #define JFW_PLUGIN_ARCH "i386"
46 #elif defined POWERPC64
47 #define JFW_PLUGIN_ARCH "ppc64"
48 #elif defined POWERPC
49 #define JFW_PLUGIN_ARCH "ppc"
50 #elif defined MIPS
51 #ifdef OSL_BIGENDIAN
52 # define JFW_PLUGIN_ARCH "mips"
53 #else
54 /* FIXME: do JDKs have some JDK-specific define? This is for
55 OpenJDK at least, but probably not true for Lemotes JDK */
56 # define JFW_PLUGIN_ARCH "mipsel"
57 #endif
58 #elif defined MIPS64
59 #ifdef OSL_BIGENDIAN
60 # define JFW_PLUGIN_ARCH "mips64"
61 #else
62 # define JFW_PLUGIN_ARCH "mips64el"
63 #endif
64 #elif defined S390X
65 #define JFW_PLUGIN_ARCH "s390x"
66 #elif defined S390
67 #define JFW_PLUGIN_ARCH "s390"
68 #elif defined ARM
69 #define JFW_PLUGIN_ARCH "arm"
70 #elif defined IA64
71 #define JFW_PLUGIN_ARCH "ia64"
72 #elif defined M68K
73 #define JFW_PLUGIN_ARCH "m68k"
74 #elif defined HPPA
75 #define JFW_PLUGIN_ARCH "parisc"
76 #elif defined AXP
77 #define JFW_PLUGIN_ARCH "alpha"
78 #elif defined AARCH64
79 #define JFW_PLUGIN_ARCH "aarch64"
80 #else // SPARC, INTEL, POWERPC, MIPS, MIPS64, ARM, IA64, M68K, HPPA, ALPHA
81 #error unknown platform
82 #endif // SPARC, INTEL, POWERPC, MIPS, MIPS64, ARM, IA64, M68K, HPPA, ALPHA
85 class MalformedVersionException : public std::exception
87 public:
88 virtual ~MalformedVersionException() override;
91 class VendorBase: public salhelper::SimpleReferenceObject
93 public:
94 VendorBase();
95 /* static char const* const * getJavaExePaths(int* size);
97 returns relative paths to the java executable as
98 file URLs.
100 For example "bin/java.exe". You need
101 to implement this function in a derived class, if
102 the paths differ. this implementation provides for
103 Windows "bin/java.exe" and for Unix "bin/java".
104 The paths are relative file URLs. That is, they always
105 contain '/' even on windows. The paths are relative
106 to the installation directory of a JRE.
109 The signature of this function must correspond to
110 getJavaExePaths_func.
113 /* static rtl::Reference<VendorBase> createInstance();
115 creates an instance of this class. MUST be overridden
116 in a derived class.
117 ####################################################
118 OVERRIDE in derived class
119 ###################################################
120 @param
121 Key - value pairs of the system properties of the JRE.
124 const OUString & getVendor() const;
125 const OUString & getVersion() const;
126 const OUString & getHome() const;
127 const OUString & getRuntimeLibrary() const;
128 const OUString & getLibraryPath() const;
129 bool supportsAccessibility() const;
130 bool isValidArch() const;
131 /* determines if prior to running java something has to be done,
132 like setting the LD_LIBRARY_PATH. This implementation checks
133 if an LD_LIBRARY_PATH (getLD_LIBRARY_PATH) needs to be set and
134 if so, needsRestart returns true.
136 bool needsRestart() const;
138 /* compares versions of this vendor. MUST be overridden
139 in a derived class.
140 ####################################################
141 OVERRIDE in derived class
142 ###################################################
143 @return
144 0 this.version == sSecond
145 1 this.version > sSecond
146 -1 this.version < sSEcond
148 @throw
149 MalformedVersionException if the version string was not recognized.
151 virtual int compareVersions(const OUString& sSecond) const = 0;
153 protected:
154 /* called automatically on the instance created by createInstance.
156 @return
157 true - the object could completely initialize.
158 false - the object could not completely initialize. In this case
159 it will be discarded by the caller.
161 virtual bool initialize(
162 std::vector<std::pair<OUString, OUString> > props);
164 /* returns relative file URLs to the runtime library.
165 For example "/bin/client/jvm.dll"
167 virtual char const* const* getRuntimePaths(int* size) = 0;
169 virtual char const* const* getLibraryPaths(int* size) = 0;
171 OUString m_sVendor;
172 OUString m_sVersion;
173 OUString m_sHome;
174 OUString m_sRuntimeLibrary;
175 OUString m_sLD_LIBRARY_PATH;
176 OUString m_sArch;
177 bool m_bAccessibility;
180 typedef rtl::Reference<VendorBase> (* createInstance_func) ();
181 friend rtl::Reference<VendorBase> createInstance(
182 createInstance_func pFunc,
183 const std::vector<std::pair<OUString, OUString> >& properties);
188 #endif
190 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */