The tempfile Standard Library
Producing temporary files is a common need in many applications. Whether you need to store something on disk to keep it out of memory until it is needed again, or you want to serve up a file but don’t need to keep it lurking around after your process has terminated, odds are you’ll run into this problem sooner or later.
It’s quite tempting to roll our own Tempfile
support, which might look something like the following code:
File.open("/tmp/foo.txt","w") do |file|
file << some_data
end
# Then in some later code
File.foreach("/tmp/foo.txt") do |line|
# do something with data
end
# Then finally
require "fileutils"
FileUtils.rm("/tmp/foo.txt")This code works, but it has some drawbacks. The first is that it assumes that you’re on a *nix system with a /tmp directory. Secondly, we don’t do anything to avoid file collisions, so if another application is using /tmp/foo.txt, this will overwrite it. Finally, we need to explicitly remove the file, or risk leaving a bunch of trash around.
Luckily, Ruby has a standard library that helps us get around these issues. Using it, our example then looks like this:
require "tempfile"
temp = Tempfile.new("foo.txt")
temp << some_data
# then in some later code
temp.rewind
temp.each do |line|
# do something with data
end
# Then finally
temp.closeLet’s take a look at what’s going on in a little more detail, to really get a sense of what the tempfile library is doing for us.
Automatic Temporary Directory Handling
The code looks somewhat ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access