X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fbindings%2FGuile.cxx;h=18d12e95eef91b5edec0624b5797a68081678546;hp=d4295c475411d2ae939c1dc0925c5f955938c200;hb=4e10c813f57981265534133a6d857fd66c6edccc;hpb=25c5224fd78d69d669d4f2722ffd2f512a65834e diff --git a/src/bindings/Guile.cxx b/src/bindings/Guile.cxx index d4295c4..18d12e9 100644 --- a/src/bindings/Guile.cxx +++ b/src/bindings/Guile.cxx @@ -12,16 +12,12 @@ namespace { GuileInterpreter::GuileInterpreter() : logger(log4cxx::Logger::getLogger("bindings.Guile")) { - QString socketpath = Settings::get()->getRuntimeDirectory()->canonicalPath() - + "/frida." + QString::number(QCoreApplication::applicationPid(), 16) + ".geiser.sock"; - scm_init_guile(); - - SCM scm_socketpath = scm_from_locale_string(socketpath.toStdString().c_str()); scm_c_use_module("system repl server"); - SCM socket = scm_call_2(scm_c_public_ref("system repl server", "make-unix-domain-server-socket"), - scm_from_locale_keyword("path"), scm_socketpath); - scm_call_1(scm_c_public_ref("system repl server", "spawn-server"), socket); + + guile::Geiser* geiser = new guile::Geiser(this); + geiser->start(); + scm_c_load_extension("libguile-frida-binding", "scm_init_frida_module"); @@ -32,14 +28,14 @@ GuileInterpreter::GuileInterpreter() LOG4CXX_INFO(logger, "Initializing GUILE finished"); } -int GuileInterpreter::evaluate(const std::string& command, - std::ostream& stdout, - std::ostream& stderr, - std::string& result) { - +int GuileInterpreter::evaluateWithErrorHandling(SCM (*fun)(void *), + void* data, + std::ostream& stdout, + std::ostream& stderr, + std::string& result) { SCM result_obj = scm_internal_catch(SCM_BOOL_T, - (SCM (*)(void *))scm_c_eval_string, - (void*)command.c_str(), + fun, + data, handler, NULL); SCM result_str = scm_object_to_string(result_obj, SCM_UNDEFINED); @@ -54,16 +50,42 @@ int GuileInterpreter::evaluate(const std::string& command, scm_truncate_file(guile_output_port, scm_from_uint16(0)); scm_truncate_file(guile_error_port, scm_from_uint16(0)); - return 0; } +int GuileInterpreter::evaluate(const std::string& command, + std::ostream& stdout, + std::ostream& stderr, + std::string& result) { + + return evaluateWithErrorHandling((SCM (*)(void *))scm_c_eval_string, + (void*)command.c_str(), + stdout, stderr, result); + +} + 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 << "\""); + LOG4CXX_DEBUG(logger, "Loading file \"" << filename << "\""); + evaluateWithErrorHandling((SCM (*)(void *))scm_c_primitive_load, + (void*)filename.c_str(), + stdout, stderr, result); + LOG4CXX_DEBUG(logger, "Finished file \"" << filename << "\""); return 0; } + +namespace guile { + void Geiser::run() { + scm_init_guile(); + + QString socketpath = Settings::get()->getRuntimeDirectory()->canonicalPath() + + "/frida." + QString::number(QCoreApplication::applicationPid(), 16) + ".geiser.sock"; + + SCM scm_socketpath = scm_from_locale_string(socketpath.toStdString().c_str()); + SCM socket = scm_call_2(scm_c_public_ref("system repl server", "make-unix-domain-server-socket"), + scm_from_locale_keyword("path"), scm_socketpath); + scm_call_1(scm_c_public_ref("system repl server", "run-server"), socket); + } +}