X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fbindings%2FGuile.cxx;h=356757d095ccb7ffb6d4a7bc4575bf4a7e70b74a;hp=57d32bdd8009d02cd8fe2fad1762cf08bb5cfbbc;hb=fd85e36ca37c93139dc7bf8d06cf71bc5a225321;hpb=fc58083a9eee8534fe3f67ddd3c020c87cd42a5f diff --git a/src/bindings/Guile.cxx b/src/bindings/Guile.cxx index 57d32bd..356757d 100644 --- a/src/bindings/Guile.cxx +++ b/src/bindings/Guile.cxx @@ -1,4 +1,5 @@ #include "Guile.hxx" +#include "Config.hxx" namespace { SCM handler (void*, SCM tag, SCM throw_args) { @@ -7,26 +8,20 @@ namespace { } } -GuileInterpreter::GuileInterpreter() { +GuileInterpreter::GuileInterpreter() + : logger(log4cxx::Logger::getLogger("bindings.Guile")) { scm_init_guile(); - scm_internal_catch(SCM_BOOL_T, - (SCM (*)(void *))scm_c_eval_string, - (void*)"(use-modules (system repl server))", - handler, NULL); - scm_internal_catch(SCM_BOOL_T, - (SCM (*)(void *))scm_c_eval_string, - (void*)"(spawn-server)", - handler, NULL); - scm_internal_catch(SCM_BOOL_T, - (SCM (*)(void *))scm_c_eval_string, - (void*)"(load-extension \"libfrida-guile\" \"scm_init_frida_module\")", - handler, NULL); + scm_c_use_module("system repl server"); + scm_call_0(scm_c_public_ref("system repl server", "spawn-server")); + scm_c_load_extension("libguile-frida-binding", + "scm_init_frida_module"); guile_output_port = scm_open_output_string(); guile_error_port = scm_open_output_string(); scm_set_current_output_port(guile_output_port); scm_set_current_error_port(guile_error_port); + LOG4CXX_INFO(logger, "Initializing GUILE finished"); } int GuileInterpreter::evaluate(const std::string& command, @@ -54,3 +49,13 @@ int GuileInterpreter::evaluate(const std::string& command, return 0; } + +int GuileInterpreter::loadFile(const std::string& filename, + std::ostream& stdout, + std::ostream& stderr, + std::string& result) { + LOG4CXX_INFO(logger, "Loading file \"" << filename << "\""); + scm_c_primitive_load(filename.c_str()); + LOG4CXX_INFO(logger, "Finished file \"" << filename << "\""); + return 0; +}