Feature #9647
closedFile::Stat#birthtimeの追加
Description
File::Stat#birthtimeを追加しませんか。
以下の様なシステムの stat(2) には st_birthtimespec があり、
(ctime = change time ではなく) ファイルを作成した日時を得ることができます。
http://netbsd.gw.com/cgi-bin/man-cgi?stat+2+NetBSD-current
http://www.freebsd.org/cgi/man.cgi?query=stat&sektion=2&apropos=0&manpath=FreeBSD+10.0-RELEASE
https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man2/stat.2.html
また、Windowsはbirthtimeがあるがctimeがないという環境ですので、birthtimeはctimeを返します。
http://msdn.microsoft.com/ja-jp/library/ms350241(v=vs.71).aspx
今回のパッチではLinuxやOpenBSDなど、struct statにbirthtimeがない環境では、
Windows同様ctimeを返すようにしています。
(が、意味が違うからWindows以外ではNotImpErrorの方がいいかも)
https://github.com/nurse/ruby/compare/ruby:trunk...birthtime
Updated by kosaki (Motohiro KOSAKI) over 10 years ago
Linuxの場合、媒体にはbirthtimeが記録されていて、syscallの追加が自転車置き場の議論で進まないという感じなのでctimeが帰ってくるのはうれしくないなあ。将来的に混乱が予想されるので。
いまでもrootならdebugfs使って作成日とれます。
この辺参照してください(一番下) http://stackoverflow.com/questions/5929419/how-to-get-file-creation-date-in-linux
こっから先は雑談なんだけど、なにが自転車置き場の議論かというと、birthtime追加 → やったSambaの実装が楽になるよ! → だがちょっと待って欲しい、Windowsはctimeユーザが変更できる、それが出来ないならSambaで使えない → それもう birthtimeじゃねーだろアホか → えーい、usecaseで揉めるような機能なら入れない!!
という非常にばかばかしい議論をしたことがあるのだ。
Updated by kosaki (Motohiro KOSAKI) over 10 years ago
更に雑談をつづけてしまうと Windowsには file system tunnelling という機能があり、われわれが birthtimeという文脈で
話すファイル作成日とは若干セマンティクスが違う
ので、名前が birthtime でいいかどうか Windows方面の人の意見を聞いたほうがいいかもしれない。
ところで、昔LKMLでだれかからWindowsはctimeのほかにユーザが自由に時刻をいじれない真のファイル作成日も媒体に
記録されていると聞いた記憶があったのだが、簡単にぐぐった限りではそんな情報はみあたらなかった。だれかそのへん
詳しい人がいたら教えていただけると助かります。
Updated by usa (Usaku NAKAMURA) over 10 years ago
NTFSでは$STANDARD_INFOMATIONと$FILE_NAMEのそれぞれに日時系メタデータが入っていますが、後者を変更するAPIは存在しないので、たぶんそれのことかと思います。
しかし、「真のファイル作成日」というよりは、そのファイル名の名付け日(例えばハードリンクを作ったならその日時)なので、ちょっと意味合いは違いますね。
Updated by naruse (Yui NARUSE) over 10 years ago
Motohiro KOSAKI wrote:
Linuxの場合、媒体にはbirthtimeが記録されていて、syscallの追加が自転車置き場の議論で進まないという感じなのでctimeが帰ってくるのはうれしくないなあ。将来的に混乱が予想されるので。
いまでもrootならdebugfs使って作成日とれます。
この辺参照してください(一番下) http://stackoverflow.com/questions/5929419/how-to-get-file-creation-date-in-linuxこっから先は雑談なんだけど、なにが自転車置き場の議論かというと、birthtime追加 → やったSambaの実装が楽になるよ! → だがちょっと待って欲しい、Windowsはctimeユーザが変更できる、それが出来ないならSambaで使えない → それもう birthtimeじゃねーだろアホか → えーい、usecaseで揉めるような機能なら入れない!!
という非常にばかばかしい議論をしたことがあるのだ。
はい。
なもんでLinuxが実装するの待っていたんですが、もう見捨てるという結論にしました(どーん
Windowsの方はなるほど…なので、とりあえずWindowsもNotImpErrorにしてうささんに実装してもらいますかね(ゎ
Updated by usa (Usaku NAKAMURA) over 10 years ago
Yui NARUSE wrote:
Windowsの方はなるほど…なので、とりあえずWindowsもNotImpErrorにしてうささんに実装してもらいますかね(ゎ
いやあの、Windowsはそれでいいので付けといてください(笑)
今のctimeのことを考えると、多少の意味の違いなんかどうでもいい感があります。
Updated by naruse (Yui NARUSE) over 10 years ago
- Status changed from Assigned to Closed
- % Done changed from 0 to 100
Applied in changeset r46047.
-
file.c (stat_birthtime): add birthtime support [Feature #9647]
-
file.c (rb_stat_birthtime): add File::Stat.birthtime
-
file.c (rb_file_s_birthtime): add File.birthtime
-
file.c (rb_file_birthtime): add File#birthtime
-
configure.in: check struct stat.st_birthtimespec.
Updated by znz (Kazuhiro NISHIYAMA) over 10 years ago
- Related to Feature #9857: Pathname#birthtime added