]> git.siccegge.de Git - frida/frida.git/commitdiff
Properly handle errors in sceme
authorChristoph Egger <siccegge@stud.informatik.uni-erlangen.de>
Thu, 27 Nov 2014 12:16:05 +0000 (13:16 +0100)
committerChristoph Egger <siccegge@stud.informatik.uni-erlangen.de>
Thu, 27 Nov 2014 12:16:05 +0000 (13:16 +0100)
Catch exceptions, no longer exit on them and print the content on the
console

src/gui/widgets/ScriptingDock.cxx
src/gui/widgets/ScriptingDock.hxx

index b3545703d3962266fb0e8afa69b310053ff39c7e..6a3f76304997eaa45992380cbc40aafb38bde214 100644 (file)
@@ -1,15 +1,36 @@
 #include "ScriptingDock.hxx"
 
+namespace {
+    SCM handler (void *data, SCM tag, SCM throw_args) {
+        scm_handle_by_message_noexit ((void*)"foo", tag, throw_args);
+               return SCM_BOOL_F;
+       }
+}
+
 void ScriptingDock::doEvaluate() {
     QString text = line->text();
     line->clear();
     LOG4CXX_INFO(logger, "Evaluating String \"" << text.toStdString() << "\"");
     browser->append(QString("> ") + text);
     
-    SCM result_obj = scm_c_eval_string(text.toStdString().c_str());
+    SCM result_obj = scm_internal_catch(SCM_BOOL_T,
+                                                                               (SCM (*)(void *))scm_c_eval_string,
+                                                                               (void*)text.toStdString().c_str(),
+                                                                               handler, NULL);
     SCM result_str = scm_object_to_string(result_obj, SCM_UNDEFINED);
 
     SCM output = scm_get_output_string(guile_output_port);
-    browser->append(scm_to_locale_string(output));
+       QString output_q = scm_to_locale_string(output);
+       if (output_q.endsWith("\n")) output_q.chop(1);
+       if (output_q != "")     browser->append(output_q);
+
+       output =  scm_get_output_string(guile_error_port);
+       output_q = scm_to_locale_string(output);
+       if (output_q.endsWith("\n")) output_q.chop(1);
+       if (output_q != "")     browser->append(output_q);
+
+       scm_truncate_file(guile_output_port, scm_from_uint16(0));
+       scm_truncate_file(guile_error_port, scm_from_uint16(0));        
+                       
     browser->append(scm_to_locale_string(result_str));
 }
index d60158be68cb9dedd4b58df448ef24f01396406f..e070955e15faeadfebcfb68922ee17d622023cd7 100644 (file)
@@ -21,17 +21,20 @@ public:
         connect(line, SIGNAL(returnPressed()), this, SLOT(doEvaluate()));
         scm_init_guile();
         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);
     }
 private:
     log4cxx::LoggerPtr logger;
-    
+
     QTextBrowser * browser;
     QGridLayout * layout;
     QPushButton * button;
     QLineEdit * line;
 
     SCM guile_output_port;
+    SCM guile_error_port;
 private slots:
     void doEvaluate();
 };