summaryrefslogtreecommitdiff
path: root/cpputools/source
diff options
context:
space:
mode:
authorJörg Budischewski <jbu@openoffice.org>2002-03-07 12:07:09 +0000
committerJörg Budischewski <jbu@openoffice.org>2002-03-07 12:07:09 +0000
commit4a33da9d71f709caa459c082a4ef1588a78dff75 (patch)
tree30597873050505aca62462b89a8edd757875a2c5 /cpputools/source
parentc6fae523c8236f9aa7e7776cfa09525342629cdb (diff)
#97931# added -s parameter, javaloader is now default for components with .jar suffixes, fixed some bugs
Diffstat (limited to 'cpputools/source')
-rw-r--r--cpputools/source/registercomponent/registercomponent.cxx221
1 files changed, 178 insertions, 43 deletions
diff --git a/cpputools/source/registercomponent/registercomponent.cxx b/cpputools/source/registercomponent/registercomponent.cxx
index 11f64a801f66..27a8faa55b11 100644
--- a/cpputools/source/registercomponent/registercomponent.cxx
+++ b/cpputools/source/registercomponent/registercomponent.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: registercomponent.cxx,v $
*
- * $Revision: 1.5 $
+ * $Revision: 1.6 $
*
- * last change: $Author: jsc $ $Date: 2001-08-17 13:00:29 $
+ * last change: $Author: jbu $ $Date: 2002-03-07 13:07:09 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -59,16 +59,22 @@
*
************************************************************************/
+#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <vector>
+#
+#include <rtl/strbuf.hxx>
#include <cppuhelper/servicefactory.hxx>
+#include <cppuhelper/shlib.hxx>
+#include <com/sun/star/container/XSet.hpp>
#include <com/sun/star/registry/XImplementationRegistration.hpp>
#include <com/sun/star/registry/XSimpleRegistry.hpp>
#include <com/sun/star/lang/XComponent.hpp>
+
#include <algorithm>
#ifndef _OSL_PROCESS_H_
@@ -92,6 +98,13 @@
using namespace ::rtl;
using namespace ::osl;
+using namespace ::cppu;
+using namespace ::std;
+using namespace ::com::sun::star::uno;
+using namespace ::com::sun::star::lang;
+using namespace ::com::sun::star::registry;
+using com::sun::star::container::XSet;
+
sal_Bool isFileUrl(const OUString& fileName)
{
@@ -123,7 +136,7 @@ OUString convertToFileUrl(const OUString& fileName)
static void usingRegisterImpl()
{
- fprintf(stderr, "\nusing: regcomp -register|revoke -r registryfile -c locationUrl [-br registryfile] [-l componentLoaderUrl]\n");
+ fprintf(stderr, "usage: regcomp -register|revoke -r registryfile -c locationUrl [-br registryfile] [-l componentLoaderUrl] [-s]\n");
fprintf(stderr, " Parameters:\n");
fprintf(stderr, " -register = register a new extern component.\n");
fprintf(stderr, " -revoke = revoke an extern component.\n\n");
@@ -136,18 +149,10 @@ static void usingRegisterImpl()
" components must all need the same loader (quoting is possible with \\ or \"\").\n");
fprintf(stderr, " -l componentLoaderUrl = the name of the needed loader, if no loader is specified\n"
" the 'com.sun.star.loader.SharedLibrary' is used.\n"
- " loaders: com.sun.star.loader.SharedLibrary | com.sun.star.loader.Java2\n\n");
+ " loaders: com.sun.star.loader.SharedLibrary | com.sun.star.loader.Java2\n"
+ " -s = silent, no output on success\n" );
}
-
-using namespace ::com::sun::star::uno;
-using namespace ::com::sun::star::lang;
-using namespace ::com::sun::star::registry;
-
-using namespace cppu;
-using namespace rtl;
-using namespace std;
-
class IllegalArgument
{
public:
@@ -163,11 +168,12 @@ struct Options
Options()
: bRegister(sal_False)
, bRevoke(sal_False)
- , sLoaderName( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.loader.SharedLibrary") )
+ , bSilent( sal_False )
{}
sal_Bool bRegister;
sal_Bool bRevoke;
+ sal_Bool bSilent;
OUString sProgramName;
OUString sBootRegName;
OUString sRegName;
@@ -180,6 +186,7 @@ sal_Bool parseOptions(int ac, char* av[], Options& rOptions, sal_Bool bCmdFile)
{
sal_Bool ret = sal_True;
sal_uInt16 i=0;
+ sal_Bool bLoaderExplicitlyGiven = sal_False;
rOptions.sProgramName = OUString::createFromAscii(av[i++]);
@@ -297,6 +304,7 @@ sal_Bool parseOptions(int ac, char* av[], Options& rOptions, sal_Bool bCmdFile)
{
i++;
rOptions.sLoaderName = OUString::createFromAscii(av[i]);
+ bLoaderExplicitlyGiven = sal_True;
} else
{
OString tmp("'-l', please check");
@@ -308,10 +316,32 @@ sal_Bool parseOptions(int ac, char* av[], Options& rOptions, sal_Bool bCmdFile)
}
} else
{
+ bLoaderExplicitlyGiven = sal_True;
rOptions.sLoaderName = OUString::createFromAscii(av[i]+2);
}
break;
}
+ case 's':
+ {
+ if( av[i][2] == 0 )
+ {
+ rOptions.bSilent = sal_True;
+ }
+ else
+ {
+ rtl::OStringBuffer buf;
+ buf.append( "Unknown error " );
+ buf.append( av[i] );
+ throw IllegalArgument( av[i] );
+ }
+ break;
+ }
+ default:
+ {
+ OString tmp( "unknown option " );
+ tmp += av[i];
+ throw IllegalArgument( tmp );
+ }
}
} else
{
@@ -324,23 +354,64 @@ sal_Bool parseOptions(int ac, char* av[], Options& rOptions, sal_Bool bCmdFile)
ret = sal_False;
} else
{
- int rargc=0;
- char* rargv[512];
- char buffer[512];
+ fseek( cmdFile , 0 , SEEK_END );
+ sal_Int32 nLen = ftell( cmdFile);
+ fseek( cmdFile, 0, SEEK_SET );
+
+ // 2 chars per string is a upper limit for the number of
+ // substrings ( at least one separator char needed for fscanf).
+ char ** rargv = (char **)rtl_allocateMemory( nLen * sizeof( char* ) /2);
+ if( ! rargv )
+ {
+ OStringBuffer buf;
+ buf.append( "Not enough memory for reading command file " );
+ buf.append( av[i] +1 );
+ buf.append( " with length " );
+ buf.append( nLen );
+ buf.append( "." );
+ throw IllegalArgument( buf.makeStringAndClear() );
+ }
+ char *buffer = ( char * )rtl_allocateMemory( nLen +1 );
+ if( ! buffer )
+ {
+ OStringBuffer buf;
+ buf.append( "Not enough memory for reading command file " );
+ buf.append( av[i] +1 );
+ buf.append( " with length " );
+ buf.append( nLen );
+ buf.append( "." );
+ throw IllegalArgument( buf.makeStringAndClear() );
+ }
+ // we start at one to omit argv[0]
+ sal_Int32 rargc = 1;
+ rargv[0] = av[0];
while ( fscanf(cmdFile, "%s", buffer) != EOF )
{
- rargv[rargc]= strdup(buffer);
+ rargv[rargc]= (char * )rtl_allocateMemory( strlen( buffer ) +1 );
+ if( ! rargv[rargc] )
+ {
+ OStringBuffer buf;
+ buf.append( "Not enough memory for reading command file " );
+ buf.append( av[i] +1 );
+ buf.append( " with length " );
+ buf.append( nLen );
+ buf.append( "." );
+ throw IllegalArgument( buf.makeStringAndClear() );
+ }
+ strcpy( rargv[rargc] , buffer );
rargc++;
}
fclose(cmdFile);
parseOptions(rargc, rargv, rOptions, bCmdFile);
- for (long i=0; i < rargc; i++)
+ for (long i=1; i < rargc; i++)
{
- free(rargv[i]);
+ rtl_freeMemory(rargv[i]);
}
+ rtl_freeMemory( buffer );
+ rtl_freeMemory( rargv );
}
} else
{
@@ -350,6 +421,25 @@ sal_Bool parseOptions(int ac, char* av[], Options& rOptions, sal_Bool bCmdFile)
}
}
+ if( ! bLoaderExplicitlyGiven && rOptions.sComponentUrls.getLength() > 4 )
+ {
+ if ( rOptions.sComponentUrls.matchAsciiL(
+ ".jar" , 4 , rOptions.sComponentUrls.getLength() - 4 ) )
+ {
+ if( ! rOptions.bSilent )
+ {
+ printf( "using loader com.sun.star.loader.Java2\n" );
+ }
+ rOptions.sLoaderName = OUString(
+ RTL_CONSTASCII_USTRINGPARAM("com.sun.star.loader.Java2"));
+ }
+ else
+ {
+ rOptions.sLoaderName = OUString(
+ RTL_CONSTASCII_USTRINGPARAM("com.sun.star.loader.SharedLibrary") );
+ }
+ }
+
return ret;
}
@@ -358,6 +448,7 @@ struct DoIt
{
sal_Bool _bRegister;
sal_Bool _bRevoke;
+ sal_Bool _bSilent;
OString _sRegName;
OUString _sLoaderName;
Reference<XImplementationRegistration> _xImplRegistration;
@@ -366,6 +457,7 @@ struct DoIt
DoIt(sal_Bool bRegister,
sal_Bool bRevoke,
+ sal_Bool bSilent,
const Reference<XSimpleRegistry> & xReg,
const OString & sRegName,
const Reference<XImplementationRegistration> & xImplRegistration,
@@ -378,6 +470,7 @@ struct DoIt
DoIt::DoIt(sal_Bool bRegister,
sal_Bool bRevoke,
+ sal_Bool bSilent,
const Reference<XSimpleRegistry> & xReg,
const OString & sRegName,
const Reference<XImplementationRegistration> & xImplRegistration,
@@ -385,6 +478,7 @@ DoIt::DoIt(sal_Bool bRegister,
sal_uInt32 * exitCode) throw()
: _bRegister(bRegister),
_bRevoke(bRevoke),
+ _bSilent( bSilent ),
_xReg(xReg),
_sRegName(sRegName),
_xImplRegistration(xImplRegistration),
@@ -398,45 +492,58 @@ void DoIt::operator() (const OUString & url) throw()
if (_bRegister)
{
- OSL_TRACE("regcomp - registering: %s in %s", sUrl.getStr(), _sRegName.getStr());
try
{
_xImplRegistration->registerImplementation(_sLoaderName, url, _xReg);
- fprintf(stderr, "\nregister component \"%s\" in registry \"%s\" succesful!\n", sUrl.getStr(), _sRegName.getStr());
+ if ( ! _bSilent )
+ {
+ fprintf(stderr, "register component '%s' in registry '%s' succesful!\n", sUrl.getStr(), _sRegName.getStr());
+ }
}
catch(CannotRegisterImplementationException & cannotRegisterImplementationException) {
OString aMessage(OUStringToOString(cannotRegisterImplementationException.Message, RTL_TEXTENCODING_ASCII_US));
- fprintf(stderr, "\nregister component \"%s\" in registry \"%s\" failed!\n", sUrl.getStr(), _sRegName.getStr());
- fprintf(stderr, "\nERROR: %s\n", aMessage.getStr());
+ fprintf(stderr, "register component '%s' in registry '%s' failed!\n", sUrl.getStr(), _sRegName.getStr());
+ fprintf(stderr, "CannotRegisterImplementationException: %s\n", aMessage.getStr());
+
+ ++ (*_exitCode);
+ }
+ catch( RuntimeException & e )
+ {
+ OString aMessage(OUStringToOString(e.Message, RTL_TEXTENCODING_ASCII_US));
+ fprintf(stderr, "register component '%s' in registry '%s' failed!\n", sUrl.getStr(), _sRegName.getStr());
+ fprintf(stderr, "RuntimeException: %s\n", aMessage.getStr());
++ (*_exitCode);
}
}
else if(_bRevoke)
{
- OSL_TRACE("regcomp - revoking: %s from %s", sUrl.getStr(), _sRegName.getStr());
-
try
{
sal_Bool bRet = _xImplRegistration->revokeImplementation(url, _xReg);
if (bRet)
- fprintf(stderr, "\nrevoke component \"%s\" from registry \"%s\" succesful!\n", sUrl.getStr(), _sRegName.getStr());
+ {
+ if ( ! _bSilent )
+ fprintf(stderr, "revoke component '%s' from registry '%s' succesful!\n", sUrl.getStr(), _sRegName.getStr());
+ }
else
{
- fprintf(stderr, "\nrevoke component \"%s\" from registry \"%s\" failed!\n", sUrl.getStr(), _sRegName.getStr());
+ fprintf(stderr, "revoke component '%s' from registry '%s' failed!\n", sUrl.getStr(), _sRegName.getStr());
- ++ (*_exitCode);
+ ++ (*_exitCode);
}
}
- catch( CannotRegisterImplementationException& e )
+ catch( RuntimeException & e )
{
- OString aMessage( OUStringToOString(e.Message, osl_getThreadTextEncoding()) );
- fprintf(stderr, "\nrevoke component \"%s\" from registry \"%s\" failed!\n", sUrl.getStr(), _sRegName.getStr());
- fprintf(stderr, "\nERROR: %s\n", aMessage.getStr() );
-
- ++ (*_exitCode);
+ OString aMessage(OUStringToOString(e.Message, RTL_TEXTENCODING_ASCII_US));
+ fprintf( stderr,
+ "revoke component '%s' from registry '%s' failed!\n",
+ sUrl.getStr(),
+ _sRegName.getStr() );
+ fprintf( stderr, "RuntimeException: %s\n" , aMessage.getStr());
+ ++ (*_exitCode);
}
}
}
@@ -475,6 +582,29 @@ void _cdecl main( int argc, char * argv[] )
} else
{
xSMgr = createServiceFactory();
+
+ // this may be added in future, when the javavm can get its initial settings
+ // from the uno context, now it is quite useless
+// if( ! aOptions.sLoaderName.compareToAscii( "com.sun.star.loader.Java2" ) )
+// {
+// // we know our java loader, so in order to make it a little easier ...
+// Reference< XInterface > r = loadSharedLibComponentFactory(
+// OUString::createFromAscii( "jen" ), OUString(),
+// OUString::createFromAscii( "com.sun.star.comp.stoc.JavaVirtualMachine" ),
+// xSMgr,
+// Reference< XRegistryKey > () );
+// Reference< XInterface > r2 = loadSharedLibComponentFactory(
+// OUString::createFromAscii( "javaloader" ), OUString(),
+// OUString::createFromAscii(( "com.sun.star.comp.stoc.JavaComponentLoader" ) ),
+// xSMgr,
+// Reference< XRegistryKey > () );
+// Reference <XSet> xSet( xSMgr, UNO_QUERY );
+// if( r.is() && r2.is() && xSet.is() )
+// {
+// xSet->insert( makeAny( r ) );
+// xSet->insert( makeAny( r2 ) );
+// }
+// }
}
}
catch( Exception& e )
@@ -482,7 +612,8 @@ void _cdecl main( int argc, char * argv[] )
fprintf(stderr, "ERROR: create ServiceManager failed!\n");
if ( e.Message.getLength() )
{
- fprintf(stderr, "ERROR description: %s\n", OUStringToOString(e.Message, osl_getThreadTextEncoding()).getStr());
+ fprintf(stderr, "ERROR description: %s\n",
+ OUStringToOString(e.Message, osl_getThreadTextEncoding()).getStr());
}
exit(1);
}
@@ -498,8 +629,6 @@ void _cdecl main( int argc, char * argv[] )
OString tmp = OUStringToOString(aOptions.sComponentUrls, osl_getThreadTextEncoding());
- OSL_TRACE("regcomp - aOptions.sComponentUrls: %s", tmp.getStr());
-
if ( aOptions.sComponentUrls.getLength() == 0 )
{
@@ -518,13 +647,17 @@ void _cdecl main( int argc, char * argv[] )
xReg->open( convertToFileUrl(aOptions.sRegName), sal_False, sal_True);
if (!xReg->isValid())
{
- fprintf(stderr, "ERROR: open|create registry \"%s\" failed!\n", sRegName.getStr());
+ fprintf(stderr, "ERROR: open|create registry '%s' failed!\n", sRegName.getStr());
exit(1);
}
}
- catch( InvalidRegistryException&)
+ catch( InvalidRegistryException & e)
{
- fprintf(stderr, "ERROR: create registry \"%s\" failed!\n", sRegName.getStr());
+ OString o = OUStringToOString( e.Message , RTL_TEXTENCODING_ASCII_US );
+ fprintf(stderr,
+ "ERROR: create registry '%s' failed!\n"
+ "InvalidRegistryException: %s\n",
+ sRegName.getStr(), o.getStr() );
exit(1);
}
}
@@ -583,7 +716,9 @@ void _cdecl main( int argc, char * argv[] )
urls.push_back(tmp_url);
if(aOptions.bRegister || aOptions.bRevoke)
- for_each(urls.begin(), urls.end(), DoIt(aOptions.bRegister, aOptions.bRevoke, xReg, sRegName, xImplRegistration, aOptions.sLoaderName, &exitCode));
+ for_each(urls.begin(), urls.end(),
+ DoIt(aOptions.bRegister, aOptions.bRevoke, aOptions.bSilent,
+ xReg, sRegName, xImplRegistration, aOptions.sLoaderName, &exitCode));
else
{
@@ -593,7 +728,7 @@ void _cdecl main( int argc, char * argv[] )
}
else
{
- fprintf(stderr, "\nComponent registration service could not be loaded!\n");
+ fprintf(stderr, "Component registration service could not be loaded!\n");
exitCode++;
}