GithubHelp home page GithubHelp logo

Comments (4)

pjeby avatar pjeby commented on May 23, 2024 1

They don't handle multiple trailing slashes correctly. Try strings like:

  • abc//
  • //xyz/..//abc//

etc. There might be other problems, I'm not sure. It's hard to do it right without using regular expression matching.

If you want to programmatically generate test cases, check out this bit of bashup/realpath's test suite: just a few lines that generate around 700 different test paths to compare the function vs. the real thing.

from pure-bash-bible.

pjeby avatar pjeby commented on May 23, 2024

Possibly worth noting is that the dirname and basename recipes given here aren't actually replacements for the dirname and basename commands. The real dirname command doesn't include a trailing /, and it returns . for a plain name, e.g. the real dirname foo returns ., but the emulation here doesn't. Similarly, the real basename command will strip multiple trailing slashes, but the emulation doesn't.

It might be worth adapting the emulations of dirname and basename from realpaths, as they're still one-liners of pure bash, but are tested to be exact equivalents to the original commands, across quite a few scenarios that the emulations here aren't valid for.

from pure-bash-bible.

dylanaraps avatar dylanaraps commented on May 23, 2024

@pjeby, both basename and dirname in the bible match their external utilities 1:1 now. If you can reproduce cases in which they don't, I'd love to know.

from pure-bash-bible.

pawamoy avatar pawamoy commented on May 23, 2024

Closing, feel free to reopen.

from pure-bash-bible.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.