Skip to content

Commit a409ca7

Browse files
authored
Merge pull request #36 from jeremyevans/copy-fifo-socket
Make copy methods handle FIFOs and UNIX sockets
2 parents 106ddaa + 20bb9ec commit a409ca7

File tree

2 files changed

+41
-9
lines changed

2 files changed

+41
-9
lines changed

lib/fileutils.rb

Lines changed: 12 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1383,18 +1383,21 @@ def copy(dest)
13831383
end
13841384
when symlink?
13851385
File.symlink File.readlink(path()), dest
1386-
when chardev?
1387-
raise "cannot handle device file" unless File.respond_to?(:mknod)
1388-
mknod dest, ?c, 0666, lstat().rdev
1389-
when blockdev?
1390-
raise "cannot handle device file" unless File.respond_to?(:mknod)
1391-
mknod dest, ?b, 0666, lstat().rdev
1386+
when chardev?, blockdev?
1387+
raise "cannot handle device file"
13921388
when socket?
1393-
raise "cannot handle socket" unless File.respond_to?(:mknod)
1394-
mknod dest, nil, lstat().mode, 0
1389+
begin
1390+
require 'socket'
1391+
rescue LoadError
1392+
raise "cannot handle socket"
1393+
else
1394+
raise "cannot handle socket" unless defined?(UNIXServer)
1395+
end
1396+
UNIXServer.new(dest).close
1397+
File.chmod lstat().mode, dest
13951398
when pipe?
13961399
raise "cannot handle FIFO" unless File.respond_to?(:mkfifo)
1397-
mkfifo dest, 0666
1400+
File.mkfifo dest, lstat().mode
13981401
when door?
13991402
raise "cannot handle door: #{path()}"
14001403
else

test/fileutils/test_fileutils.rb

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -430,6 +430,35 @@ def test_cp_r_symlink_preserve
430430
}
431431
end if have_symlink? and !no_broken_symlink?
432432

433+
def test_cp_r_fifo
434+
Dir.mkdir('tmp/cpr_src')
435+
File.mkfifo 'tmp/cpr_src/fifo', 0600
436+
cp_r 'tmp/cpr_src', 'tmp/cpr_dest'
437+
assert_equal(true, File.pipe?('tmp/cpr_dest/fifo'))
438+
end if File.respond_to?(:mkfifo)
439+
440+
def test_cp_r_dev
441+
devs = Dir['/dev/*']
442+
chardev = Dir['/dev/*'].find{|f| File.chardev?(f)}
443+
blockdev = Dir['/dev/*'].find{|f| File.blockdev?(f)}
444+
Dir.mkdir('tmp/cpr_dest')
445+
assert_raise(RuntimeError) { cp_r chardev, 'tmp/cpr_dest/cd' }
446+
assert_raise(RuntimeError) { cp_r blockdev, 'tmp/cpr_dest/bd' }
447+
end
448+
449+
begin
450+
require 'socket'
451+
rescue LoadError
452+
else
453+
def test_cp_r_socket
454+
skip "Skipping socket test on JRuby" if RUBY_ENGINE == 'jruby'
455+
Dir.mkdir('tmp/cpr_src')
456+
UNIXServer.new('tmp/cpr_src/socket').close
457+
cp_r 'tmp/cpr_src', 'tmp/cpr_dest'
458+
assert_equal(true, File.socket?('tmp/cpr_dest/socket'))
459+
end if defined?(UNIXServer)
460+
end
461+
433462
def test_cp_r_pathname
434463
# pathname
435464
touch 'tmp/cprtmp'

0 commit comments

Comments
 (0)