summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--ext/socket/socket.c12
-rw-r--r--string.c11
3 files changed, 17 insertions, 11 deletions
diff --git a/ChangeLog b/ChangeLog
index 3d46c2d1aa..70dcf2a8e7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Thu Nov 4 21:25:38 2004 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * string.c (str_gsub): string modify check no longer based on
+ tmplock. [ruby-dev:24706]
+
Thu Nov 4 21:13:48 2004 Masaki Suketa <masaki.suketa@nifty.ne.jp>
* ext/win32ole/win32ole.c(typelib_file_from_typelib): search "win16"
diff --git a/ext/socket/socket.c b/ext/socket/socket.c
index 4cc9adc072..cbd3dd86ce 100644
--- a/ext/socket/socket.c
+++ b/ext/socket/socket.c
@@ -1303,8 +1303,7 @@ static VALUE
unixsock_connect_internal(arg)
struct unixsock_arg *arg;
{
- return (VALUE)ruby_connect(arg->fd, arg->sockaddr, sizeof(*arg->sockaddr),
- 0);
+ return (VALUE)ruby_connect(arg->fd, arg->sockaddr, sizeof(*arg->sockaddr), 0);
}
static VALUE
@@ -1984,18 +1983,21 @@ sock_connect(sock, addr)
VALUE sock, addr;
{
OpenFile *fptr;
- int fd;
+ int fd, n;
StringValue(addr);
rb_str_modify(addr);
GetOpenFile(sock, fptr);
fd = fileno(fptr->f);
- if (ruby_connect(fd, (struct sockaddr*)RSTRING(addr)->ptr, RSTRING(addr)->len, 0) < 0) {
+ rb_str_locktmp(addr);
+ n = ruby_connect(fd, (struct sockaddr*)RSTRING(addr)->ptr, RSTRING(addr)->len, 0);
+ rb_str_unlocktmp(addr);
+ if (n < 0) {
rb_sys_fail("connect(2)");
}
- return INT2FIX(0);
+ return INT2FIX(n);
}
static VALUE
diff --git a/string.c b/string.c
index d36f82ba46..fb56d3063d 100644
--- a/string.c
+++ b/string.c
@@ -464,7 +464,6 @@ str_independent(str)
VALUE str;
{
if (FL_TEST(str, STR_TMPLOCK)) {
- FL_UNSET(str, STR_TMPLOCK);
rb_raise(rb_eRuntimeError, "can't modify string; temporarily locked");
}
if (OBJ_FROZEN(str)) rb_error_frozen("string");
@@ -2045,9 +2044,9 @@ str_gsub(argc, argv, str, bang)
VALUE pat, val, repl, match, dest;
struct re_registers *regs;
long beg, n;
- long offset, blen, len;
+ long offset, blen, slen, len;
int iter = 0;
- char *buf, *bp, *cp;
+ char *buf, *bp, *sp, *cp;
int tainted = 0;
if (argc == 1 && rb_block_given_p()) {
@@ -2074,9 +2073,9 @@ str_gsub(argc, argv, str, bang)
dest = rb_str_new5(str, 0, blen);
buf = RSTRING(dest)->ptr;
bp = buf;
- cp = RSTRING(str)->ptr;
+ sp = cp = RSTRING(str)->ptr;
+ slen = RSTRING(str)->len;
- rb_str_locktmp(str);
rb_str_locktmp(dest);
while (beg >= 0) {
n++;
@@ -2085,7 +2084,7 @@ str_gsub(argc, argv, str, bang)
if (iter) {
rb_match_busy(match);
val = rb_obj_as_string(rb_yield(rb_reg_nth_match(0, match)));
- str_mod_check(dest, buf, blen);
+ str_mod_check(str, sp, slen);
rb_backref_set(match);
}
else {