[#6828] bug in mailread.rb, and: proposal for Mail#to_s — Wybo Dekker <wybo@...>
mailread separates mail messages looking for /^From /.
Hi,
[#6847] Re: Proposed patch for optparse to fix multi line argument handling — Daniel Hobe <hobe@...>
The attached patch fixes a bug in Optparse (at least I think it is a
Hi,
[#6864] ruby 1.8.4 rc breaks alias_method/rails in bad ways — "Ara.T.Howard" <ara.t.howard@...>
Ara.T.Howard wrote:
On Tue, 13 Dec 2005, [ISO-8859-15] Florian Growrote:
On Dec 12, 2005, at 1:19 PM, ara.t.howard@noaa.gov wrote:
On Tue, 13 Dec 2005, James Edward Gray II wrote:
On Dec 12, 2005, at 1:42 PM, ara.t.howard@noaa.gov wrote:
On Dec 12, 2005, at 2:10 PM, James Edward Gray II wrote:
On Tue, 13 Dec 2005, James Edward Gray II wrote:
[#6888] Iconv library - differences between Ruby 1.8.2 and 1.8.4? — "Dave Burt" <dave@...>
Hi,
[#6891] Time.utc! and Time.localtime! — Daniel Hobe <hobe@...>
Writing a script yesterday I found out, much to my surprise, that the
On Dec 14, 2005, at 11:36 AM, Daniel Hobe wrote:
Hi,
[#6894] Dir.tmpdir RDoc — Eric Hodel <drbrain@...7.net>
Speaking of tmpdir, I'm curious why the tmpdir source
[#6906] Add Missing HTTP Headers and Status Codes to Ruby CGI — Paul Duncan <pabs@...>
Hi Everyone,
[#6911] IO.open not calling close in block form? — Daniel Berger <Daniel.Berger@...>
What happened to the block form of IO.open after 1.8.2? It's supposed to
[#6918] change to yaml in 1.8.4 — ara.t.howard@...
-----BEGIN PGP SIGNED MESSAGE-----
On Sat, 17 Dec 2005, Jeremy Kemper wrote:
On Sat, 2005-12-17 at 03:10 +0900, ara.t.howard@noaa.gov wrote:
On Dec 16, 2005, at 2:57 PM, Tom Copeland wrote:
On Sat, 2005-12-17 at 09:02 +0900, Eric Hodel wrote:
On Dec 16, 2005, at 5:30 PM, Tom Copeland wrote:
[#6934] 1.8.x, YAML, and release management — Ryan Davis <ryand-ruby@...>
I'm concerned that 1.8.3's acceptance of non-backwards-compatible
Hi.
Ryan Davis (ryand-ruby@zenspider.com) wrote:
On Saturday 17 December 2005 22:18, Ryan Davis wrote:
Hi.
[#6964] Array Documentation Issues — James Edward Gray II <james@...>
Let's start with:
[#6979] ruby 1.8.4 preview3 — Yukihiro Matsumoto <matz@...>
Hi,
[#6980] Re: ruby 1.8.4 preview3 — Kailden <kailden@...>
matz> I have just put 1.8.4 preview3 on the server.
[#6996] Problems building 1.8.4 with VS8 C++ Express Edition (cl 14.00) — Austin Ziegler <halostatue@...>
Visual Studio C++ 2005 Express Edition (VS 8.0)
Hello,
On 26/12/05, U.Nakamura <usa@garbagecollect.jp> wrote:
>>> __pioinfo structure may have been changed.
Hi.
I have replaced the config/makefile setup for Ruby using C++ Express, and I
Hi,
Hello,
Hi,
On 27/12/05, nobuyoshi nakada <nobuyoshi.nakada@ge.com> wrote:
Hello,
[#7008] Install fails to create directories — noreply@...
Bugs item #3115, was opened at 2005-12-28 05:00
Hi,
[#7028] Ruby 1.8.4 RDoc HTML Cleanups and HTML Language Support — Paul Duncan <pabs@...>
Hi,
Hi.
* H.Yamamoto (ocean@m2.ccsnet.ne.jp) wrote:
* H.Yamamoto (ocean@m2.ccsnet.ne.jp) wrote:
Re: getpasswd
Hi,
At Thu, 22 Dec 2005 09:00:56 +0900,
Bertram Scharpf wrote in [ruby-core:06973]:
> The reason is easy to find: the `static struct passwd' that
> is used internally by both the `Etc::passwd' method and
> `expand_path' substitute-~ mechanism. `Etc' even seems to
> protect itself from using the struct twice using a static
> variable named `passwd_blocking'.
Hmmm, get{pw,gr}*_r() family aren't actually reentrant at all.
Just a dirty hack. Otherwise, iterative methods in etc.c
would have to read all items at first.
Index: file.c
===================================================================
RCS file: /cvs/ruby/src/ruby/file.c,v
retrieving revision 1.233
diff -U2 -p -r1.233 file.c
--- file.c 21 Dec 2005 09:20:00 -0000 1.233
+++ file.c 22 Dec 2005 05:32:09 -0000
@@ -92,4 +92,29 @@ be_fchown(int fd, uid_t owner, gid_t gro
#endif /* __BEOS__ */
+#ifdef HAVE_PWD_H
+int rb_passwd_blocking;
+
+struct passwd *
+rb_getpwnam(const char *name)
+{
+ if (rb_passwd_blocking) {
+ rb_raise(rb_eRuntimeError, "parallel passwd iteration");
+ }
+ return getpwnam(name);
+}
+
+struct passwd *
+rb_getpwuid(rb_uid_t uid)
+{
+ if (rb_passwd_blocking) {
+ rb_raise(rb_eRuntimeError, "parallel passwd iteration");
+ }
+ return getpwuid(uid);
+}
+
+#define getpwnam rb_getpwnam
+#define getpwuid rb_getpwuid
+#endif
+
VALUE rb_cFile;
VALUE rb_mFileTest;
Index: process.c
===================================================================
RCS file: /cvs/ruby/src/ruby/process.c,v
retrieving revision 1.142
diff -U2 -p -r1.142 process.c
--- process.c 20 Nov 2005 03:30:43 -0000 1.142
+++ process.c 22 Dec 2005 05:32:05 -0000
@@ -117,4 +117,28 @@ static VALUE S_Tms;
do {int saved_errno = errno; stmts; errno = saved_errno;} while (0)
+#ifdef HAVE_GRP_H
+int rb_group_blocking;
+
+struct group *
+rb_getgrnam(const char *name)
+{
+ if (rb_group_blocking) {
+ rb_raise(rb_eRuntimeError, "parallel group iteration");
+ }
+ return getgrnam(name);
+}
+
+struct group *
+rb_getgrgid(rb_gid_t gid)
+{
+ if (rb_group_blocking) {
+ rb_raise(rb_eRuntimeError, "parallel group iteration");
+ }
+ return getgrgid(gid);
+}
+
+#define getgrnam rb_getgrnam
+#define getgrgid rb_getgrgid
+#endif
/*
Index: ext/etc/etc.c
===================================================================
RCS file: /cvs/ruby/src/ruby/ext/etc/etc.c,v
retrieving revision 1.20
diff -U2 -p -r1.20 etc.c
--- ext/etc/etc.c 12 Dec 2005 00:35:07 -0000 1.20
+++ ext/etc/etc.c 22 Dec 2005 05:08:56 -0000
@@ -108,4 +108,7 @@ setup_passwd(pwd)
);
}
+
+RUBY_EXTERN int rb_passwd_blocking;
+#define passwd_blocking rb_passwd_blocking
#endif
@@ -170,5 +173,4 @@ etc_getpwnam(obj, nam)
#ifdef HAVE_GETPWENT
-static int passwd_blocking = 0;
static VALUE
passwd_ensure()
@@ -317,4 +319,7 @@ setup_group(grp)
mem);
}
+
+RUBY_EXTERN int rb_group_blocking;
+#define group_blocking rb_group_blocking
#endif
@@ -375,5 +380,4 @@ etc_getgrnam(obj, nam)
#ifdef HAVE_GETGRENT
-static int group_blocking = 0;
static VALUE
group_ensure()
--
Nobu Nakada