Skip to content

Commit

Permalink
Promoted File#path to IO#path, added path: optional param to IO#new
Browse files Browse the repository at this point in the history
  • Loading branch information
moste00 committed Sep 21, 2023
1 parent b4a05b5 commit 175a645
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 6 deletions.
4 changes: 0 additions & 4 deletions src/main/ruby/truffleruby/core/file.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1161,7 +1161,6 @@ class << self
def initialize(path_or_fd, mode = nil, perm = nil, **options)
if Primitive.is_a?(path_or_fd, Integer)
super(path_or_fd, mode, **options)
@path = nil
else
path = Truffle::Type.coerce_to_path path_or_fd
nmode, _binary, _external, _internal, _autoclose, perm = Truffle::IOOperations.normalize_options(mode, perm, options)
Expand Down Expand Up @@ -1208,9 +1207,6 @@ def stat
Stat.fstat Primitive.io_fd(self)
end

def path
@path.dup
end
alias_method :to_path, :path

def truncate(length)
Expand Down
7 changes: 6 additions & 1 deletion src/main/ruby/truffleruby/core/io.rb
Original file line number Diff line number Diff line change
Expand Up @@ -846,7 +846,7 @@ def initialize(fd, mode = nil, **options)
@external = nil
@pid = nil

mode, binary, external, internal, autoclose_tmp, _perm = Truffle::IOOperations.normalize_options(mode, nil, options)
mode, binary, external, internal, autoclose_tmp, _perm, path = Truffle::IOOperations.normalize_options(mode, nil, options)

fd = Truffle::Type.coerce_to(fd, Integer, :to_int)
sync = fd == 2 # stderr is always unbuffered, see setvbuf(3)
Expand All @@ -857,6 +857,7 @@ def initialize(fd, mode = nil, **options)

@autoclose = autoclose_tmp
@pipe = false
@path = path unless @path
end

##
Expand Down Expand Up @@ -1221,6 +1222,10 @@ def prepare_read_string(str)
@lineno += 1
end

def path
@path.dup
end

##
# Return a string describing this IO object.
def inspect
Expand Down
6 changes: 5 additions & 1 deletion src/main/ruby/truffleruby/core/truffle/io_operations.rb
Original file line number Diff line number Diff line change
Expand Up @@ -543,10 +543,14 @@ def self.normalize_options(mode, perm, options, default_mode = nil)
external, internal = encoding.split(':', 2)
end
end

if options[:path]
path = options[:path]
end
end
external = Encoding::BINARY if binary and !external and !internal
perm ||= 0666
[mode, binary, external, internal, autoclose, perm]
[mode, binary, external, internal, autoclose, perm, path]
end
end
end

0 comments on commit 175a645

Please sign in to comment.