class KLibLoader

The KLibLoader allows you to load libraries dynamically at runtime. More...

Definition#include <klibloader.h>
InheritsQObject (qt) [public ]
List of all Methods
Annotated List
Files
Globals
Hierarchy
Index

Public Methods

Public Static Methods

Protected Methods


Detailed Description

The KLibLoader allows you to load libraries dynamically at runtime. Dependent libraries are loaded automatically.

KLibLoader follows the singleton pattern. You can not create multiple instances. Use self() to get a pointer to the loader.

 ~KLibLoader ()

~KLibLoader

You should NEVER destruct an instance of KLibLoader until you know what you are doing. This will release the loaded libraries.

KLibFactory*  factory ( const char* libname )

factory

Loads and initializes a library. Loading a library multiple times is handled gracefully.

This is a convenience function that returns the factory immediately

See also: library

KLibrary*  library ( const char* libname )

library

[virtual]

Loads and initializes a library. Loading a library multiple times is handled gracefully.

You can, however, give a library name ending in ".so" (or whatever is used on your platform), and the library will be loaded without resolving dependencies. USE WITH CARE :)

Parameters:
libnameThis is the library name without extension. Usually that is something like "libkspread". The function will then search for a file named "libkspread.la" in the KDE library paths. The *.la files are created by libtool and contain important information especially about the libraries dependencies on other shared libs. Loading a "libfoo.so" could not solve the dependencies problem.

Returns: KLibrary is invalid (0) when the library couldn't be dlopened. in such a case you can retrieve the error message by calling KLibLoader::lastErrorMessage()

See also: factory

KLibrary*  globalLibrary ( const char *name )

globalLibrary

Loads and initializes a library. Loading a library multiple times is handled gracefully. The library is loaded such that the symbols are globally accessible so libraries with dependencies can be loaded sequentially.

You can, however, give a library name ending in ".so" (or whatever is used on your platform), and the library will be loaded without resolving dependencies. USE WITH CARE :)

Parameters:
libnameThis is the library name without extension. Usually that is something like "libkspread". The function will then search for a file named "libkspread.la" in the KDE library paths. The *.la files are created by libtool and contain important information especially about the libraries dependencies on other shared libs. Loading a "libfoo.so" could not solve the dependencies problem.

Returns: KLibrariy is invalid (0) when the library couldn't be dlopened. in such a case you can retrieve the error message by calling KLibLoader::lastErrorMessage()

See also: factory

QString  lastErrorMessage ()

lastErrorMessage

[const]

void  unloadLibrary ( const char *libname )

unloadLibrary

[virtual]

KLibLoader*  self ()

self

[static]

Returns: a pointer to the loader. If no loader exists until now then one is created.

void  cleanUp ()

cleanUp

[static]

This is what makes it possible to rely on ~KLibFactory being called in all cases, whether the library is unloaded while the application is running or when exiting.

QString  findLibrary ( const char * name, const KInstance * instance = KGlobal::instance() )

findLibrary

[static]

Helper method which looks for a library in the standard paths ("module" and "lib" resources) Made public for code that doesn't use KLibLoader itself, but still wants to open modules.

 KLibLoader ( QObject* parent = 0, const char* name = 0 )

KLibLoader

[protected]

void  virtual_hook ( int id, void* data )

virtual_hook

[protected virtual]