Age | Commit message (Collapse) | Author | |
---|---|---|---|
2020-11-11 | Release 2.12.1 | Tavian Barnes | |
2020-11-11 | tests: Don't squelch stderr with --verbose | Tavian Barnes | |
2020-11-10 | tests: Test LS_COLORS extension lowercasing | Tavian Barnes | |
2020-11-10 | Makefile: New gcov target | Tavian Barnes | |
2020-11-10 | opt: Assert that we don't do disabled optimizations | Tavian Barnes | |
2020-11-10 | tests: Improve test coverage a bit | Tavian Barnes | |
2020-11-09 | tests: Add missing expectations from dd3bbb9 | Tavian Barnes | |
2020-11-09 | opt: Predicates aren't true when they're false | Tavian Barnes | |
This unfortunate typo was mostly harmless; since the predicates were always assumed to be true, they wouldn't conflict. The exception is -user/-group, which set -nouser/-nogroup to false for users/groups that exist. Even -O0 wasn't enough to suppress the bug, due to a missing optlevel check fixed in the previous commit. Fixes: 305ee902874b49351f4916e303c293523f11570b | |||
2020-11-09 | opt: Check optlevel before removing unreachable expressions | Tavian Barnes | |
2020-11-09 | Use two newlines for all pre-eval warnings | Tavian Barnes | |
2020-11-04 | eval: Fix the status bar to only print the parent again | Tavian Barnes | |
2020-11-04 | eval: Make a crude attempt to handle double-width chars in the status bar | Tavian Barnes | |
2020-11-04 | Enable -Wsign-compare to catch bugs like 726d7801 | Tavian Barnes | |
2020-11-04 | spawn: Fix error pipe write failure handling | Tavian Barnes | |
A short history lesson: this code (from exec.c) used to just be write(...); In 649d85b, an empty if block was added to placate _FORTIFY_SOURCE's warn_unused_result: if (write(...) != sizeof(error)) { // ... } This is fine since the parent doesn't rely on receiving those writes (e.g. the child could die before writing), and the small write to a pipe won't fail anyway. But when bfs_spawn() was created, the implementation changed to this: while (write(...) < sizeof(error)); The while loop was presumably added to mirror musl's posix_spawn() implementation, which handles EINTR. But musl's is actually correct: while (write(...) < 0); whereas mine has a subtle bug: since sizeof(error) is unsigned, the bfs code did an unsigned comparison, meaning -1 from write() would *not* restart the loop. Fix it by comparing with 0 like musl, since short writes are impossible here. Perhaps it's time for -Wsign-compare, despite the other 18 instances being false positives. | |||
2020-11-03 | Makefile: Fail early on sanitizer errors | Tavian Barnes | |
2020-11-03 | New -status option to display a status bar | Tavian Barnes | |
2020-11-03 | bar: Implement terminal status bars | Tavian Barnes | |
2020-11-03 | dstring: New dstrvprintf() function | Tavian Barnes | |
2020-10-14 | Update the project URL | Tavian Barnes | |
2020-10-14 | Release 2.02.0 | Tavian Barnes | |
2020-10-13 | util: New BFS_FLEX_SIZEOF() macro for more precise flexible array allocations | Tavian Barnes | |
See http://www.open-std.org/jtc1/sc22/wg14/www/docs/dr_282.htm for all the fun behind this. | |||
2020-10-06 | pwcache: Adjust some naming conventions | Tavian Barnes | |
2020-10-06 | mtab: Adjust some naming conventions | Tavian Barnes | |
2020-10-06 | expr, eval: Clean up header dependencies | Tavian Barnes | |
2020-10-06 | exec: Adjust some calling conventions | Tavian Barnes | |
2020-10-06 | printf: Adjust some calling conventions | Tavian Barnes | |
2020-10-06 | ctx: Don't include color.h | Tavian Barnes | |
2020-10-05 | diag: New bfs_perror() function | Tavian Barnes | |
2020-10-04 | parse: Fail if -color is passed and the colors couldn't be parsed | Tavian Barnes | |
2020-10-04 | parse: More accurate error reporting for cfdup() | Tavian Barnes | |
2020-10-04 | parse: Report errors when failing to add a root | Tavian Barnes | |
2020-10-04 | diag: Factor debug_flag string conversion into its own function | Tavian Barnes | |
2020-10-01 | time: Don't call tzset() on every x{local,gm}time() | Tavian Barnes | |
It turns out tzset() checks /etc/localtime every time you call it. | |||
2020-10-01 | dstring: Try to avoid calling vsnprintf() twice in dstrprintf() | Tavian Barnes | |
2020-10-01 | main: Preserve errno over close() in redirect() | Tavian Barnes | |
2020-10-01 | util: Move redirect() and isopen() to main.c | Tavian Barnes | |
2020-09-30 | util: Don't rely on bftw | Tavian Barnes | |
And rename format_mode() to xstrmode() while I'm at it. | |||
2020-09-28 | ctx: Perserve errno better in bfs_ctx_open() | Tavian Barnes | |
2020-09-27 | Rename struct cmdline to bfs_ctx | Tavian Barnes | |
The API remains similar, with some added accessor functions for lazy initialization of the pwcache and mtab. | |||
2020-09-23 | exec: Output a human-readable description of terminating signals | Tavian Barnes | |
2020-09-20 | bftw: Fix bftw_cached_stat() with BFS_STAT_TRYFOLLOW | Tavian Barnes | |
2020-09-20 | tests: Add missing ground truth | Tavian Barnes | |
2020-09-20 | printf: Format the empty string for %l of non-links | Tavian Barnes | |
It makes a difference if the format specifier has a width. | |||
2020-09-18 | stat: Rename bfs_stat_flag to _flags | Tavian Barnes | |
Flags enums should be plural. | |||
2020-09-18 | Don't call stat() just to determine symbolic lengths | Tavian Barnes | |
The new bftw_cached_stat() helper gets us stat info if we already have it, but doesn't call stat() if we don't. In that case we just take a guess for the initial length to readlinkat(). This lets us avoid stat() entirely in many cases for -lname and -printf %l. | |||
2020-09-18 | util: Make the initial allocation bigger for xreadlinkat() | Tavian Barnes | |
Most symlinks are more than 1 character long, so rather than wasting time with 1, 2, 4, ... when we don't have a good guess for the length, start with a bigger one. Credit to https://twitter.com/RichFelker/status/1306321019108556806 for reminding me of this. | |||
2020-09-02 | pwcache: Fix an invalid free if strdup()ing the group name fails | Tavian Barnes | |
2020-08-13 | pwcache: Work around gr_mem being misaligned on macOS | Tavian Barnes | |
C.f. https://github.com/php/php-src/commit/d80f0ff6c0a557d8c993a9d2bd006fb488f6d564 | |||
2020-08-13 | Implement -xattrname | Tavian Barnes | |
From macOS find. | |||
2020-07-29 | bftw: Make some flag names more explicit | Tavian Barnes | |