Hacker News new | ask | show | jobs
by devnonymous 3253 days ago
Bash has a few builtin that are clones of commands (mostly from coreutils). To execute the command instead of the builtin, just give the full path to the command (not sure and cannot verify, right now but this might mean either /bin/ulimit or /use/bin/ulimit ). There are other notable ones like echo, and time where the builtins have slightly different behaviour than the commands.
1 comments

While what you said is true in general; ulimit is usually not a separate program. It modifies the state of the current process (similarly to `cd`), so it has to be built-in.

Now, there's no solid reason why it couldn't work like `unshare` or `chroot` (which also wrap operations that modify the current process), and spawn a second child shell with the modified properties. But, that isn't how it works on any system I have ever used, isn't what users expect, and isn't in conformance with POSIX.

To quote POSIX: Since `ulimit` affects the current shell execution environment, it is always provided as a shell regular built-in.

> so it has to be built-in.

We have fork() and exec(), and resource limits carry across exec(), so it does not /have/ to be a built-in.