summaryrefslogtreecommitdiff
path: root/src/plugins/scripts/ruby/weechat-ruby.c
diff options
context:
space:
mode:
authorEmmanuel Bouthenot <kolter@openics.org>2006-02-21 22:43:48 +0000
committerEmmanuel Bouthenot <kolter@openics.org>2006-02-21 22:43:48 +0000
commit3a79e32dbb31af7d17d35819e0648b010b310ec5 (patch)
treee07d1e3c49c4472eb6bfc6d514eb93ee63a386ad /src/plugins/scripts/ruby/weechat-ruby.c
parent349d9d1028c000415b57a50eb717dde410344a1a (diff)
downloadweechat-3a79e32dbb31af7d17d35819e0648b010b310ec5.zip
fix minor bug and improve backtrace display on errors
Diffstat (limited to 'src/plugins/scripts/ruby/weechat-ruby.c')
-rw-r--r--src/plugins/scripts/ruby/weechat-ruby.c35
1 files changed, 27 insertions, 8 deletions
diff --git a/src/plugins/scripts/ruby/weechat-ruby.c b/src/plugins/scripts/ruby/weechat-ruby.c
index 19b7ccce6..13e4d1d3b 100644
--- a/src/plugins/scripts/ruby/weechat-ruby.c
+++ b/src/plugins/scripts/ruby/weechat-ruby.c
@@ -106,7 +106,7 @@ weechat_ruby_exec (t_weechat_plugin *plugin,
t_plugin_script *script,
char *function, char *server, char *arguments)
{
- VALUE ruby_retcode;
+ VALUE ruby_retcode, err;
int ruby_error;
/* make gcc happy */
(void) plugin;
@@ -123,8 +123,12 @@ weechat_ruby_exec (t_weechat_plugin *plugin,
"Ruby error: unable to run function \"%s\"",
function);
- rb_eval_string_protect("Weechat.print(\"Ruby error: \" + $@.to_s)", NULL);
- rb_eval_string_protect("Weechat.print(\"Ruby error: \" + $!.to_s)", NULL);
+ err = rb_inspect(rb_gv_get("$!"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ /*
+ err = rb_inspect(rb_gv_get("$@"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ */
return PLUGIN_RC_KO;
}
@@ -1371,7 +1375,7 @@ int
weechat_ruby_load (t_weechat_plugin *plugin, char *filename)
{
char modname[64];
- VALUE curModule, ruby_retcode;
+ VALUE curModule, ruby_retcode, err;
int ruby_error;
plugin->print_server (plugin, "Loading Ruby script \"%s\"", filename);
@@ -1389,6 +1393,16 @@ weechat_ruby_load (t_weechat_plugin *plugin, char *filename)
free (ruby_current_script_filename);
+ if (ruby_retcode == Qnil) {
+ err = rb_inspect(rb_gv_get("$!"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ /*
+ err = rb_inspect(rb_gv_get("$@"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ */
+ return 0;
+ }
+
if (NUM2INT(ruby_retcode) != 0)
{
VALUE ruby_eval_error;
@@ -1398,7 +1412,7 @@ weechat_ruby_load (t_weechat_plugin *plugin, char *filename)
case 1:
ruby_plugin->print_server (ruby_plugin,
"Ruby error: unable to read file \"%s\"",
- filename);
+ filename);
break;
case 2:
@@ -1431,10 +1445,15 @@ weechat_ruby_load (t_weechat_plugin *plugin, char *filename)
{
ruby_plugin->print_server (ruby_plugin,
"Ruby error: unable to eval weechat_init in file \"%s\"",
- filename);
- rb_eval_string_protect("Weechat.print(\"Ruby error: \" + $@.to_s)", NULL);
- rb_eval_string_protect("Weechat.print(\"Ruby error: \" + $!.to_s)", NULL);
+ filename);
+ err = rb_inspect(rb_gv_get("$!"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ /*
+ err = rb_inspect(rb_gv_get("$!"));
+ ruby_plugin->print_server (ruby_plugin, "Ruby error: \"%s\"", STR2CSTR(err));
+ */
+
if (ruby_current_script != NULL)
weechat_script_remove (plugin, &ruby_scripts, ruby_current_script);
return 0;