2002-10-16 17:28:17 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#define LT_SCOPE extern /* so that ltdl.h does not export anything */
|
|
|
|
#include <ltdl.h>
|
|
|
|
#define MAIN_DLL_EXPORT
|
|
|
|
#include "main.h"
|
|
|
|
|
|
|
|
const char *version_string = "uselib-test6-1.0";
|
|
|
|
|
|
|
|
int register_module (const char *name)
|
|
|
|
{
|
|
|
|
printf ("register_module was called by module '%s'\n", name);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-10-17 10:49:44 +04:00
|
|
|
int load_module (const char *fmt, const char *modname)
|
2002-10-16 17:28:17 +04:00
|
|
|
{
|
|
|
|
char buf[512];
|
2002-10-17 10:49:44 +04:00
|
|
|
sprintf (buf, fmt, modname);
|
2002-10-16 17:28:17 +04:00
|
|
|
printf ("loading module from VARIES{%s}\n", buf);
|
|
|
|
lt_dlhandle handle = lt_dlopenext (buf);
|
|
|
|
printf ("handle is VARIES{%p}\n", handle);
|
|
|
|
if (!handle) {
|
|
|
|
printf ("lt_dlopen error: %s\n", lt_dlerror ());
|
|
|
|
return -1;
|
|
|
|
}
|
2002-10-17 10:49:44 +04:00
|
|
|
char sym[1024];
|
|
|
|
sprintf (sym, "%s_LTX_%s", modname, "module_init");
|
|
|
|
modload_func func = (modload_func) lt_dlsym (handle, sym);
|
2002-10-16 17:28:17 +04:00
|
|
|
printf ("module_init function is at VARIES{%p}\n", func);
|
|
|
|
if (func != NULL) {
|
|
|
|
printf ("Calling module_init\n");
|
|
|
|
(*func)();
|
|
|
|
} else {
|
|
|
|
printf ("lt_dlsym error: %s\n", lt_dlerror ());
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
Widget* widgets[10];
|
|
|
|
|
|
|
|
void init_widgets ()
|
|
|
|
{
|
|
|
|
widgets[0] = new Widget (1, "Fred", 1.01);
|
|
|
|
widgets[1] = new Widget (2, "Erma", 0.76);
|
|
|
|
widgets[2] = new Widget (3, "Mikhail", 2.25);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main (int argc, char **argv)
|
|
|
|
{
|
|
|
|
printf ("start\n");
|
|
|
|
init_widgets ();
|
|
|
|
if (lt_dlinit () != 0) {
|
|
|
|
printf ("lt_dlinit error: %s\n", lt_dlerror ());
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
#ifdef WIN32
|
|
|
|
const char *module_name_format = "%s";
|
|
|
|
#else
|
|
|
|
const char *module_name_format = "lib%s.la";
|
|
|
|
#endif
|
|
|
|
printf ("loading module1\n");
|
|
|
|
// try to load module1
|
|
|
|
if (load_module (module_name_format, "module1") < 0) {
|
|
|
|
printf ("load module1 failed\n");
|
|
|
|
}
|
|
|
|
if (load_module (module_name_format, "module2") < 0) {
|
|
|
|
printf ("load module2 failed\n");
|
|
|
|
}
|
|
|
|
int arg;
|
|
|
|
for (int arg=1; arg < argc; arg++) {
|
|
|
|
if (load_module (module_name_format, argv[arg]) < 0) {
|
|
|
|
printf ("load %s failed\n", argv[arg]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
printf ("stop\n");
|
|
|
|
exit (77);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
///// Widget class implementation
|
|
|
|
Widget::Widget(int id, const char* name, float weight)
|
|
|
|
{
|
|
|
|
this->id = id;
|
|
|
|
this->name = name;
|
|
|
|
this->weight = weight;
|
|
|
|
}
|
|
|
|
|
|
|
|
int Widget::getId ()
|
|
|
|
{
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* Widget::getName ()
|
|
|
|
{
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
|
|
|
float Widget::getWeight ()
|
|
|
|
{
|
|
|
|
return weight;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Widget::print (FILE* fp)
|
|
|
|
{
|
|
|
|
fprintf (fp, "[Widget id=%d, name='%s', weight=%.4f]", id, name, weight);
|
|
|
|
}
|