1 /* dynl-shl.c - dynamic linking with shl_load (HP-UX)
3 * Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2, or (at your option)
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software; see the file COPYING. If not, write to
17 * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
19 * As a special exception, the Free Software Foundation gives permission
20 * for additional uses of the text contained in its release of GUILE.
22 * The exception is that, if you link the GUILE library with other files
23 * to produce an executable, this does not by itself cause the
24 * resulting executable to be covered by the GNU General Public License.
25 * Your use of that executable is in no way restricted on account of
26 * linking the GUILE library code into it.
28 * This exception does not however invalidate any other reasons why
29 * the executable file might be covered by the GNU General Public License.
31 * This exception applies only to the code released by the
32 * Free Software Foundation under the name GUILE. If you copy
33 * code from other Free Software Foundation releases into a copy of
34 * GUILE, as the General Public License permits, the exception does
35 * not apply to the code that you add in this way. To avoid misleading
36 * anyone as to the status of such modified files, you must delete
37 * this exception notice from them.
39 * If you write modifications of your own for GUILE, it is your choice
40 * whether to permit this exception to apply to your modifications.
41 * If you do not wish that, delete this exception notice.
44 /* "dynl.c" dynamically link&load object files.
46 Modified for libguile by Marius Vollmer */
54 #define SHL(obj) ((shl_t*)SCM_CDR(obj))
56 static int printshl
SCM_P ((SCM exp
, SCM port
, scm_printstate
*pstate
));
59 prinshl (exp
, port
, pstate
)
62 scm_printstate
*pstate
;
64 scm_gen_puts (scm_regular_string
, "#<dynamic-linked ", port
);
65 scm_intprint (SCM_CDR (exp
), 16, port
);
66 scm_gen_putc ('>', port
);
71 static scm_smobfuns shlsmob
= { scm_mark0
, scm_free0
, prinshl
};
73 SCM_PROC (s_dynamic_link
, "dynamic-link", 1, 0, 0, scm_dynamic_link
);
76 scm_dynamic_link (fname
)
82 fname
= scm_coerce_rostring (fname
, s_dynamic_link
, SCM_ARG1
);
85 shl
= shl_load (SCM_CHARS (fname
), BIND_DEFERRED
, 0L);
87 scm_misc_error (s_dynamic_link
, "dynamic linking failed", SCM_EOL
);
89 SCM_SETCHARS (z
, shl
);
90 SCM_SETCAR (z
, scm_tc16_shl
);
96 SCM_PROC (s_dynamic_call
, "dynamic-call", 2, 0, 0, scm_dynamic_call
);
99 scm_dynamic_call (symb
, shl
)
105 symb
= scm_coerce_rostring (symb
, s_dynamic_call
, SCM_ARG1
);
106 SCM_ASSERT (SCM_NIMP (shl
) && SCM_CAR (shl
) == scm_tc16_shl
, shl
, SCM_ARG2
,
110 if (shl_findsym (&SHL(shl
), SCM_CHARS(symb
), TYPE_PROCEDURE
, &func
))
111 scm_misc_error (s_dynamic_call
, "undefined function",
112 scm_cons (symb
, SCM_EOL
));
119 SCM_PROC (s_dynamic_args_call
, "dynamic-args-call", 3, 0, 0, scm_dynamic_args_call
);
122 scm_dynamic_args_call (symb
, shl
, args
)
127 int (*func
) SCM_P ((int argc
, char **argv
)) = 0;
129 symb
= scm_coerce_rostring (symb
, s_dynamic_args_call
, SCM_ARG1
);
130 SCM_ASSERT (SCM_NIMP (shl
) && SCM_CAR(shl
) == scm_tc16_shl
, shl
, SCM_ARG2
,
131 s_dynamic_args_call
);
134 if (shl_findsym(&SHL(shl
), SCM_CHARS(symb
), TYPE_PROCEDURE
, &func
))
135 scm_misc_error (s_dynamic_call
, "undefined function: %s",
136 scm_cons (symb
, SCM_EOL
));
137 argv
= scm_make_argv_from_stringlist (args
, &argc
, s_dynamic_args_call
,
141 i
= (*func
) (argc
, argv
);
144 scm_must_free_argv (argv
);
146 return SCM_MAKINUM (0L+i
);
149 SCM_PROC (s_dynamic_unlink
, "dynamic-unlink", 1, 0, 0, scm_dynamic_unlink
);
152 scm_dynamic_unlink (shl
)
156 SCM_ASSERT (SCM_NIMP (shl
) && SCM_CAR (shl
) == scm_tc16_shl
, shl
,
157 SCM_ARG1
, s_dynamic_unlink
);
160 status
= shl_unload (SHL (shl
));
168 scm_init_dynamic_linking ()
170 scm_tc16_shl
= scm_newsmob (&shlsmob
);