-rw-r--r-- | microkde/kdecore/klibloader.cpp | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/microkde/kdecore/klibloader.cpp b/microkde/kdecore/klibloader.cpp index 1410308..130cc7c 100644 --- a/microkde/kdecore/klibloader.cpp +++ b/microkde/kdecore/klibloader.cpp | |||
@@ -152,17 +152,18 @@ KLibFactory* KLibrary::factory() | |||
152 | return m_factory; | 152 | return m_factory; |
153 | 153 | ||
154 | QCString symname; | 154 | QCString symname; |
155 | symname.sprintf("init_%s", name().latin1() ); | 155 | symname.sprintf("init_%s", name().latin1() ); |
156 | 156 | ||
157 | void* sym = symbol( symname ); | 157 | void* sym = symbol( symname ); |
158 | if ( !sym ) | 158 | if ( !sym ) |
159 | { | 159 | { |
160 | kdWarning(150) << "KLibrary: The library " << name() << " does not offer an init_" << name() << " function" << endl; | 160 | qDebug("KLibrary: The library %s does not offer an %s function", name().latin1(), symname.data()); |
161 | kdWarning(150) << "KLibrary: The library " << name().latin1() << " does not offer an init_" << name().latin1() << " function" << endl; | ||
161 | return 0; | 162 | return 0; |
162 | } | 163 | } |
163 | 164 | ||
164 | typedef KLibFactory* (*t_func)(); | 165 | typedef KLibFactory* (*t_func)(); |
165 | t_func func = (t_func)sym; | 166 | t_func func = (t_func)sym; |
166 | m_factory = func(); | 167 | m_factory = func(); |
167 | 168 | ||
168 | if( !m_factory ) | 169 | if( !m_factory ) |
@@ -363,26 +364,39 @@ QString KLibLoader::findLibrary( const char * name/*US , const KInstance * insta | |||
363 | QCString libname( name ); | 364 | QCString libname( name ); |
364 | 365 | ||
365 | // only append ".la" if there is no extension | 366 | // only append ".la" if there is no extension |
366 | // this allows to load non-libtool libraries as well | 367 | // this allows to load non-libtool libraries as well |
367 | // (mhk, 20000228) | 368 | // (mhk, 20000228) |
368 | int pos = libname.findRev('/'); | 369 | int pos = libname.findRev('/'); |
369 | if (pos < 0) | 370 | if (pos < 0) |
370 | pos = 0; | 371 | pos = 0; |
371 | if (libname.find('.', pos) < 0) | 372 | /*US |
373 | if (libname.find('.', pos) < 0) { | ||
372 | libname += ".la"; | 374 | libname += ".la"; |
375 | } | ||
376 | */ | ||
377 | //US in the microedition we work only with shared libraries. | ||
378 | if (libname.find('.', pos) < 0) { | ||
379 | libname += ".so"; | ||
380 | } | ||
373 | 381 | ||
374 | // only look up the file if it is not an absolute filename | 382 | // only look up the file if it is not an absolute filename |
375 | // (mhk, 20000228) | 383 | // (mhk, 20000228) |
376 | QString libfile; | 384 | QString libfile; |
377 | if (libname[0] == '/') | 385 | if (libname[0] == '/') |
378 | libfile = libname; | 386 | libfile = libname; |
379 | else | 387 | else |
380 | { | 388 | { |
389 | //US at this point the libname must exist as real filesname. No expansions will be made later | ||
390 | // in findResources. Because of that we prepend the lib prefix here to the name | ||
391 | //US I add also the "lib" prefix. I do not how could this could have worked before without it? | ||
392 | libname.insert(pos, "lib"); | ||
393 | |||
394 | |||
381 | //US libfile = instance->dirs()->findResource( "module", libname ); | 395 | //US libfile = instance->dirs()->findResource( "module", libname ); |
382 | libfile = KGlobal::dirs()->findResource( "module", libname ); | 396 | libfile = KGlobal::dirs()->findResource( "module", libname ); |
383 | if ( libfile.isEmpty() ) | 397 | if ( libfile.isEmpty() ) |
384 | { | 398 | { |
385 | //US libfile = instance->dirs()->findResource( "lib", libname ); | 399 | //US libfile = instance->dirs()->findResource( "lib", libname ); |
386 | libfile = KGlobal::dirs()->findResource( "lib", libname ); | 400 | libfile = KGlobal::dirs()->findResource( "lib", libname ); |
387 | #ifndef NDEBUG | 401 | #ifndef NDEBUG |
388 | if ( !libfile.isEmpty() && libname.left(3) == "lib" ) // don't warn for kdeinit modules | 402 | if ( !libfile.isEmpty() && libname.left(3) == "lib" ) // don't warn for kdeinit modules |
@@ -390,16 +404,19 @@ QString KLibLoader::findLibrary( const char * name/*US , const KInstance * insta | |||
390 | #endif | 404 | #endif |
391 | } | 405 | } |
392 | if ( libfile.isEmpty() ) | 406 | if ( libfile.isEmpty() ) |
393 | { | 407 | { |
394 | #ifndef NDEBUG | 408 | #ifndef NDEBUG |
395 | kdDebug(150) << "library=" << libname << ": No file names " << libname.data() << " found in paths." << endl; | 409 | kdDebug(150) << "library=" << libname << ": No file names " << libname.data() << " found in paths." << endl; |
396 | #endif | 410 | #endif |
397 | self()->d->errorMessage = i18n("Library files for \"%1\" not found in paths").arg(libname); | 411 | self()->d->errorMessage = i18n("Library files for \"%1\" not found in paths").arg(libname); |
412 | |||
413 | qDebug("KLibLoader::library could not find library: %s", libname.data()); | ||
414 | |||
398 | } | 415 | } |
399 | else | 416 | else |
400 | self()->d->errorMessage = QString::null; | 417 | self()->d->errorMessage = QString::null; |
401 | } | 418 | } |
402 | return libfile; | 419 | return libfile; |
403 | } | 420 | } |
404 | 421 | ||
405 | 422 | ||
@@ -449,19 +466,16 @@ KLibrary* KLibLoader::library( const char *name ) | |||
449 | wrap->lib = new KLibrary( name, wrap->filename, wrap->handle ); | 466 | wrap->lib = new KLibrary( name, wrap->filename, wrap->handle ); |
450 | } | 467 | } |
451 | wrap->ref_count++; | 468 | wrap->ref_count++; |
452 | } else { | 469 | } else { |
453 | QString libfile = findLibrary( name ); | 470 | QString libfile = findLibrary( name ); |
454 | if ( libfile.isEmpty() ) | 471 | if ( libfile.isEmpty() ) |
455 | return 0; | 472 | return 0; |
456 | 473 | ||
457 | const QString & qpeDir = QPEApplication::qpeDir(); | ||
458 | libfile = qpeDir + libfile; | ||
459 | //US QLibrary *lib = new QLibrary( qpeDir + "/plugins/korganizer/libopiekabc.so", QLibrary::Immediately ); | ||
460 | QLibrary *qlib = new QLibrary( libfile.latin1(), QLibrary::Immediately ); | 474 | QLibrary *qlib = new QLibrary( libfile.latin1(), QLibrary::Immediately ); |
461 | 475 | ||
462 | //US lt_dlhandle handle = lt_dlopen( libfile.latin1() ); | 476 | //US lt_dlhandle handle = lt_dlopen( libfile.latin1() ); |
463 | //US if ( !handle ) | 477 | //US if ( !handle ) |
464 | if ( !qlib ) | 478 | if ( !qlib ) |
465 | { | 479 | { |
466 | //US const char* errmsg = lt_dlerror(); | 480 | //US const char* errmsg = lt_dlerror(); |
467 | char* errmsg; | 481 | char* errmsg; |