Files
libreoffice/jvmfwk/source/fwkutil.hxx
Oliver Bolte ce33a15311 INTEGRATION: CWS jl64 (1.12.80); FILE MERGED
2007/06/07 07:52:58 jl 1.12.80.2: #i76390# support of new bootstrap variable UNO_JAVA_JFW_INSTALL_DATA and UNO_JAVA_JFW_INSTALL_EXPIRE
2007/06/04 08:05:45 jl 1.12.80.1: #i76390 do not create user installation when installing java extensions during setup
2007-06-13 06:58:34 +00:00

148 lines
4.3 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: fwkutil.hxx,v $
*
* $Revision: 1.13 $
*
* last change: $Author: obo $ $Date: 2007-06-13 07:58:34 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#if !defined INCLUDED_JVMFWK_FWKUTIL_HXX
#define INCLUDED_JVMFWK_FWKUTIL_HXX
#include "sal/config.h"
#include "osl/mutex.hxx"
#include "rtl/bootstrap.hxx"
#include "rtl/instance.hxx"
#include "rtl/ustrbuf.hxx"
#include "rtl/byteseq.hxx"
#include "osl/thread.hxx"
namespace jfw
{
/** Returns the file URL of the directory where the framework library
(this library) resides.
*/
rtl::OUString getLibraryLocation();
/** provides a bootstrap class which already knows the values from the
jvmfkwrc file.
*/
struct Bootstrap :
public ::rtl::StaticWithInit< const rtl::Bootstrap *, Bootstrap > {
const rtl::Bootstrap * operator () () {
::rtl::OUStringBuffer buf(256);
buf.append(getLibraryLocation());
buf.appendAscii(SAL_CONFIGFILE("/jvmfwk3"));
::rtl::OUString sIni = buf.makeStringAndClear();
::rtl::Bootstrap * bootstrap = new ::rtl::Bootstrap(sIni);
#if OSL_DEBUG_LEVEL >=2
rtl::OString o = rtl::OUStringToOString( sIni , osl_getThreadTextEncoding() );
fprintf(stderr, "[Java framework] Using configuration file %s\n" , o.getStr() );
#endif
return bootstrap;
}
};
struct FwkMutex: public ::rtl::Static<osl::Mutex, FwkMutex> {};
//osl::Mutex * getFwkMutex();
rtl::ByteSequence encodeBase16(const rtl::ByteSequence& rawData);
rtl::ByteSequence decodeBase16(const rtl::ByteSequence& data);
rtl::OUString getPlatform();
//const rtl::Bootstrap& getBootstrap();
rtl::OUString getDirFromFile(const rtl::OUString& usFilePath);
rtl::OUString getFileFromURL(const rtl::OUString& sFileURL);
/** Returns the file URL of the folder where the executable resides.
*/
rtl::OUString getExecutableDirectory();
/** Locates the plugin library and returns the file URL.
First tries to locate plugin relative to baseUrl. If that fails, tries to
locate plugin relative to the executable. If that fails, and plugin
contains no slashes, tries to locate plugin in a platform-specific way
(e.g., LD_LIBRARY_PATH).
@param baseUrl
The base file URL relative to which the plugin argument is interpreted.
@param plugin
The argument is just the name of the plugin or a relative path
from the directory of the executable.
*/
rtl::OUString findPlugin(
const rtl::OUString & baseUrl, const rtl::OUString & plugin);
enum FileStatus
{
FILE_OK,
FILE_DOES_NOT_EXIST,
FILE_INVALID
};
/** checks if the URL is a file.
If it is a link to a file than
it is resolved. Assuming that the argument
represents a relative URL then FILE_INVALID
is returned.
@return
one of the values of FileStatus.
@exception
Errors occured during determining if the file exists
*/
FileStatus checkFileURL(const rtl::OUString & path);
struct PluginLibrary;
class VersionInfo;
class CJavaInfo;
bool isAccessibilitySupportDesired();
rtl::OUString buildClassPathFromDirectory(const rtl::OUString & relPath);
rtl::OUString retrieveClassPath( ::rtl::OUString const & macro );
}
#endif