Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

modified File.dirname to accept an optional number of levels to strip of the path, Ruby 3.1 support. #2907

Merged
merged 2 commits into from
Mar 15, 2023

Conversation

moste00
Copy link
Contributor

@moste00 moste00 commented Mar 6, 2023

An issue in #2733, making File.dirname accept an optional argument to repeat its behaviour, a default value of 1 reduces the method to its original behaviour.

@oracle-contributor-agreement oracle-contributor-agreement bot added the OCA Verified All contributors have signed the Oracle Contributor Agreement. label Mar 6, 2023
return +'/' unless idx
num_levels.times do
# edge case
return +'.' if path.empty?
Copy link
Member

@andrykonchin andrykonchin Mar 7, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does it make sense to check path.empty? on each iteration but not only once at the beginning?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess so, since I'm modifying path every iteration, it can potentially become empty every iteration.

This check is actually the first check in the original File.dirname, I just left it in its place here instead of moving it with the rest into FileOperations.dirname_once, because it seems intuitive that if a path ever becomes empty that we early return right away instead of continuing to call dirname_once uselessly.

Copy link
Member

@andrykonchin andrykonchin Mar 7, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not a big deal actually, but the helper method returns either:

  • "."
  • "/"
  • path.byteslice(0, pos)
  • path.byteslice(0, idx - 1)

So I assume it shouldn't return empty String. Or it can?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tested it just now in ruby 3.1.0, it can :

irb(main):004:0> "hello".byteslice(0,0)
=> ""

so if idx is 1 or pos is 0 it will return an empty string.

#Helper to File.dirname, extracts the directory of a path (doesn't need to handle the empty string)
#This was the original File.dirname, but ruby 3.1 made File.dirname take an optional number of times to do its logic
#So the original method now becomes calling this in a loop, hence the renaming with "_once" appended
def self.dirname_once(path)
Copy link
Member

@andrykonchin andrykonchin Mar 7, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TBH the method name is a bit confusing. I would consider something more obvious like "dirname_remove_last_segment" or "...without_last_segment" etc.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, I think the name is just a nod to the fact that this where most of the logic for File.dirname is performed, and the visible File.dirname is just calling it in a loop, I agree it seems confusing at first glance.

I think "dirname_without_last_segment" is redundant, since the "dirname" part already implies the "without_last_segment", right ? Ideally we want something that have 'dirname' and then some indicator of "oneness" to imply that it will do so only once, or maybe we should ditch "dirname" entirely and just rename it like "remove_last_segment_from_path" ?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like the term "path" here 👍 .

I don't have strong opinion on this subjective topic and I am OK with any name that makes it obvious what a method does without looking through its code.

Copy link
Member

@eregon eregon Mar 8, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would just name it dirname since it is what dirname(1) does.
The fact it's under Truffle::FileOperations implies it's a helper method and doesn't do all the logic, and one can easily look at File.dirname to see how they use each other.

File.dirname(obj,0).should .equal?(obj)

obj = Object.new
File.dirname(obj,0).should .equal?(obj)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good catch!

I noticed there is another missing test case - when level is greater than actual file name directories number, I mean

File.dirname('/a/b', 10) # => '/'

@andrykonchin
Copy link
Member

Also could you please squash commits into a single one, or several commits if they reflect separate atomic changes or steps.

@moste00 moste00 force-pushed the File.dirname_ruby3.1 branch 2 times, most recently from 4761dc1 to 5484f1d Compare March 7, 2023 19:21
Copy link
Member

@andrykonchin andrykonchin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me 👍

There may be some minor formatting issues. Also the single commit doesn't have a meaningful name.

Comment on lines 82 to 83
#Helper to File.dirname, extracts the directory of a path (doesn't need to handle the empty string)
#This was the original File.dirname, but ruby 3.1 made File.dirname take an optional number of times to do its logic
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Style-wise, the convention is always having a space after # (for comments).

@andrykonchin andrykonchin force-pushed the File.dirname_ruby3.1 branch from 129c27a to 18d7445 Compare March 14, 2023 18:04
@graalvmbot graalvmbot merged commit 550d47b into oracle:master Mar 15, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
OCA Verified All contributors have signed the Oracle Contributor Agreement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants