summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--signal.c2
-rw-r--r--variable.c15
3 files changed, 16 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index 73586e435a..2c2ba5a991 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Wed Aug 28 23:59:15 2002 Michal Rokos <michal@ruby-lang.org>
+
+ * signal.c: remove #ifdef SIGINT for struct signals.
+
+ * variable.c: get rid of fix length buffer in rb_class_path.
+
Wed Aug 28 23:34:32 2002 Nobuyoshi Nakada <nobu.nokada@softhome.net>
* io.c (appendline): data was lost when raw mode.
diff --git a/signal.c b/signal.c
index 6b2d50563f..a4331a9f15 100644
--- a/signal.c
+++ b/signal.c
@@ -36,9 +36,7 @@ static struct signals {
#ifdef SIGHUP
{"HUP", SIGHUP},
#endif
-#ifdef SIGINT
{"INT", SIGINT},
-#endif
#ifdef SIGQUIT
{"QUIT", SIGQUIT},
#endif
diff --git a/variable.c b/variable.c
index bed89593d6..28b3f965ba 100644
--- a/variable.c
+++ b/variable.c
@@ -188,17 +188,22 @@ rb_class_path(klass)
if (path) return path;
else {
- char buf[256];
+ VALUE str;
char *s = "Class";
if (TYPE(klass) == T_MODULE) {
- if (rb_obj_class(klass) == rb_cModule)
+ if (rb_obj_class(klass) == rb_cModule) {
s = "Module";
- else
+ }
+ else {
s = rb_class2name(RBASIC(klass)->klass);
+ }
}
- sprintf(buf, "#<%s:0x%lx>", s, klass);
- return rb_str_new2(buf);
+ str = rb_str_new(0, 2 + strlen(s) + 3 + 2 * SIZEOF_LONG + 1);
+ sprintf(RSTRING(str)->ptr, "#<%s:0x%lx>", s, klass);
+ RSTRING(str)->len = strlen(RSTRING(str)->ptr);
+
+ return str;
}
}