Merge pull request #5009 from reitermarkus/atomic_write
Fix `atomic_write` inside non-sticky directory.
This commit is contained in:
commit
72f2bb2643
@ -160,9 +160,16 @@ class Pathname
|
||||
open("a", *open_args) { |f| f.puts(content) }
|
||||
end
|
||||
|
||||
# NOTE always overwrites
|
||||
# NOTE: This always overwrites.
|
||||
def atomic_write(content)
|
||||
# The enclosing `mktmpdir` and the `chmod` are a workaround
|
||||
# for https://github.com/rails/rails/pull/34037.
|
||||
Dir.mktmpdir(".d", dirname) do |tmpdir|
|
||||
begin
|
||||
FileUtils.chmod "+t", dirname
|
||||
rescue Errno::EPERM
|
||||
:ignore
|
||||
end
|
||||
File.atomic_write(self, tmpdir) do |file|
|
||||
file.write(content)
|
||||
end
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user