[#7878] libwww-ruby — TAKAHASHI Masayoshi <maki@...>

高橋です。ごぶさたしています。

31 messages 1998/05/13
[#7881] RE: libwww-ruby — OZAWA Sakuro <crouton@...> 1998/05/13

さく%札幌出張@塩尻です.

[#7882] Re: libwww-ruby — matz@... (Yukihiro Matsumoto) 1998/05/14

まつもと ゆきひろです

[#7884] Re: libwww-ruby — Eiji-usagi-MATSUmoto <ematsu@...> 1998/05/14

うさぎです

[#7885] Re: libwww-ruby — matz@... (Yukihiro Matsumoto) 1998/05/14

まつもと ゆきひろです

[#7886] Re: libwww-ruby — Eiji-usagi-MATSUmoto <ematsu@...> 1998/05/14

うさぎです

[#7888] Re: libwww-ruby — Mitsuru Ogino <ogino@...> 1998/05/14

ちょっとした疑問ですが。

[#7904] Re: filename (Re: libwww-ruby) — 助田 雅紀 <masaki.suketa@...>

助田です。

19 messages 1998/05/15
[#7908] Re: filename (Re: libwww-ruby) — ttate@... 1998/05/15

立石@JAISTです。

[#7909] Ruby Application Archive (Re: Re: filename (Re: libwww-ruby)) — matz@... (Yukihiro Matsumoto) 1998/05/15

まつもと ゆきひろです

[#7912] Re: filename (Re: libwww-ruby) — Makoto Nukui <gnue@...>

ども、GNUE(鵺)です。

16 messages 1998/05/15
[#7926] Re: filename (Re: libwww-ruby) — TAKAHASHI Masayoshi <maki@...> 1998/05/15

高橋です。

[#7965] links from ruby home page — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

28 messages 1998/05/18
[#7966] Re: links from ruby home page — WATANABE Tetsuya <tetsu@...> 1998/05/18

>>>>> "matz" == Yukihiro Matsumoto <matz@netlab.co.jp> writes:

[#7967] Re: links from ruby home page — matz@... (Yukihiro Matsumoto) 1998/05/18

まつもと ゆきひろです

[#7968] Re: links from ruby home page — WATANABE Tetsuya <tetsu@...> 1998/05/18

>>>>> "matz" == Yukihiro Matsumoto <matz@netlab.co.jp> writes:

[#7969] Re: links from ruby home page — matz@... (Yukihiro Matsumoto) 1998/05/18

まつもと ゆきひろです

[#7974] Re: links from ruby home page — matz@... (Yukihiro Matsumoto) 1998/05/18

まつもと ゆきひろです

[#7979] dbm — Kazuhiro HIWADA <hiwada@...> 1998/05/18

ひわだといいます。こんにちは。

[#7990] Re: dbm — matz@... (Yukihiro Matsumoto) 1998/05/19

まつもと ゆきひろです

[#8002] Dir.open order — Kikutani Makoto <kikutani@...>

きくたに@マサチューセッツです。

13 messages 1998/05/19

[#8099] cathedral v.s. bazaar — Kikutani Makoto <kikutani@...>

debian-usersで話題になってる

23 messages 1998/05/27
[#8103] Re: cathedral v.s. bazaar — TAKAHASHI Masayoshi <maki@...> 1998/05/28

高橋です。

[#8104] Re: cathedral v.s. bazaar — WATANABE Tetsuya <tetsu@...> 1998/05/28

>>>>> "T" == TAKAHASHI Masayoshi <maki@inac.co.jp> writes:

[#8106] Re: cathedral v.s. bazaar — ttate@... 1998/05/28

立石@JAISTです。

[ruby-list:7919] Re: libwww-ruby

From: NAGAI Hidetoshi <nagai@...>
Date: 1998-05-15 08:15:21 UTC
List: ruby-list #7919
永井@知能.九工大です.

>>>>> "M" == Yukihiro Matsumoto <matz@netlab.co.jp> writes:
M> まつもと ゆきひろです
M> In message "[ruby-list:7888] Re: libwww-ruby"
M>     on 98/05/14, Mitsuru Ogino <ogino@coop.nagoya-u.ac.jp> writes:
M> |> Mac 上の httpd が URI の区切りと OS のパス区切りの面倒を見てい
M> |> るように, ruby も中で面倒をみてあげて, script 上では「/」で統一
M> |> というのが嬉しいように思いますね.
M> |そうなると「あるファイル 98/5/1」なんてファイル名を扱うときはどうなるんで
M> |しょうか?
M> ふむ.スクリプトの移植性とMacでの使い勝手との対立って感じで
M> すかね.あんまり考えてなかったなあ.

Mac のことは全く知らないので自信はないのですが,
以下のようなものではいかがでしょうか?

スクリプト上でのパス区切りが何かは何らかの変数で指定できるとします.
デフォルトでは '/' としておきます.
スクリプト上と OS 上とでパス区切りが違うならば,
open などの際に例えば ':' <-> '/' というように
指定ファイル名の変換をしてあげようというわけです.
スクリプト上で想定しているパス区切り文字は,
ファイル名の一部とはしないはずであるという考えが根底にあります.

Mac 上で「foo:98/5/1」(ってディレクトリ foo のファイル 98/5/1 
ということでいいのですよね?(^_^; ) については,
スクリプト上でのパス区切りを '/' とするのであれば,
スクリプト上では「foo/98:5:1」として指定します.
これに対し,OS 上のパス区切りが ':' であれば,
ファイルアクセスの際に,内部的に「foo:98/5/1」に変換します.
逆にスクリプト上でのパス区切りを ':' と指定すれば,
スクリプト上では Mac 的に「foo:98/5/1」と書け,
UNIX 系では「foo/98:5:1」に変換してアクセスされます.

これにより,使い慣れた方のパス区切りでのファイル名指定で
スクリプトを組め,一般的には可搬になると言えないでしょうか?(^_^;
ただし,組み込み関数 system に渡す引数に付いてもこれを行うべきか,
行ってもよいのかは十分検討していないのでよくわかりません.

# コマンド呼び出しを含む場合の可搬性はもともと低いので,
# 最初から考える必要はないのかな???

これ以外に問題となるのは,スクリプトを読む際に
スクリプト上のパス区切りを意識しないといけないことと,
スクリプト上と実際に作成されるものとでファイル名が異なる点ですが,
これらは可搬性向上のために目をつぶるということで.;;;^_^;;;

なお,このファイル名変換はメソッドとしても用意しておき,
ユーザからのファイル名入力を受け付ける際には
このメソッドによってスクリプト上の形式に揃えるようにします.
可搬性を考えるなら,ユーザによるファイル名指定を受け取る際には
このメソッドによるファイル名チェックを行うというわけです.

-- 
                                         永井 秀利 (九工大 知能情報)
                                             nagai@ai.kyutech.ac.jp

In This Thread