summaryrefslogtreecommitdiffstats
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
...
* xspawn: Do $PATH resolution up-frontTavian Barnes2023-11-071-21/+19
| | | | | | | | | posix_spawnp() is typically implemented like execvp(), i.e., by repeatedly trying execv() with each $PATH component until it succeeds. This is much slower than resolving the executable path up-front and then calling execv() once, so do that. Fixes: https://github.com/tavianator/bfs/pull/127#issuecomment-1795095126
* Treat NO_COLOR="" the same as unsetTavian Barnes2023-11-061-1/+2
| | | | | | | | | | | | | | The docs say > Command-line software which adds ANSI color to its output by default > should check for a NO_COLOR environment variable that, when present > and not an empty string (regardless of its value), prevents the > addition of ANSI color. but we were not checking for the empty string. Link: https://no-color.org/ Link: https://github.com/sharkdp/fd/pull/1421
* exec: Try harder to use posix_spawn()Tavian Barnes2023-11-061-5/+26
|
* xspawn: Wrap the real posix_spawn() if possibleTavian Barnes2023-11-063-48/+136
| | | | Fixes #47.
* ctx: Store the original and current RLIMIT_NOFILETavian Barnes2023-11-065-37/+38
|
* bfstd: Expose rlim_cmp()Tavian Barnes2023-11-063-33/+40
|
* bftw: Improve ioq balancing logicTavian Barnes2023-11-011-13/+22
|
* bfstd: New xwaitpid() wrapperTavian Barnes2023-10-315-3/+19
|
* bftw: Leave work for the main thread if profitableTavian Barnes2023-10-311-4/+13
|
* thread: Move thread wrapper functions out of lineTavian Barnes2023-10-272-32/+99
|
* typo: Shrink the key_coords tableTavian Barnes2023-10-271-2/+3
|
* Use {0} to initialize mbstate_t rather than memset()Tavian Barnes2023-10-272-12/+6
|
* eval: TTY-escape paths in the status barTavian Barnes2023-10-271-4/+8
|
* bfstd: Expose xmbrtowc() and use it in eval_status()Tavian Barnes2023-10-273-38/+46
|
* bfstd: Only free the locale if we dup'd it successfullyTavian Barnes2023-10-261-3/+3
|
* wordesc: Don't allow braces in bare wordsTavian Barnes2023-10-181-1/+1
| | | | Things like {a,b} should be quoted to avoid brace expansion.
* parse: Set BFTW_WHITEOUTS when parsing -type wTavian Barnes2023-10-171-0/+3
|
* bftw: New flag to control whiteout visibilityTavian Barnes2023-10-173-2/+19
|
* dir: New flag to control whiteout visibilityTavian Barnes2023-10-172-3/+13
|
* dir: Fix FreeBSD union mountsTavian Barnes2023-10-171-8/+46
|
* dir: Add a flags parameter to bfs_opendir()Tavian Barnes2023-10-176-21/+45
|
* dir: Fix Android buildTavian Barnes2023-10-141-1/+1
| | | | Android doesn't provide a getdents() wrapper, so use the syscall.
* Release 3.0.43.0.4Tavian Barnes2023-10-121-1/+1
|
* bfstd: Actually use the copied localeTavian Barnes2023-10-121-1/+1
| | | | This fixes a segfault in xstrerror() when using musl.
* Release 3.0.33.0.3Tavian Barnes2023-10-121-1/+1
|
* bftw: Make sure we don't close a directory while we unwrap itTavian Barnes2023-10-121-2/+6
| | | | | | | bftw_cache_reserve() can lead to bftw_cache_pop(), which could close the directory we're trying to unwrap! If that happened, we would try dup_cloexec(-1), which would fail with EBADF, so there was no observable bug. But it's better to avoid the whole situation.
* bftw: Fix to_close list corruption with !BFS_USE_UNWRAPDIRTavian Barnes2023-10-121-6/+13
| | | | | | | | | | It's possible for pincount to drop to zero, then get incremented and drop back to zero again. If this happens, we shouldn't add it to the to_close list twice. This should fix the intermittent hang on the macOS CI. Fixes: 815798e1eea7fc8dacd5acab40202ec4d251d517
* list: Assert that we're not inserting already-attached nodesTavian Barnes2023-10-122-21/+46
|
* diag: Move enum debug_flags out of ctx.hTavian Barnes2023-10-124-53/+54
|
* bftw: Don't force buffering for parallel dfsTavian Barnes2023-10-121-5/+30
|
* bftw: Fix unbuffered depth-first searchesTavian Barnes2023-10-121-15/+41
| | | | | | | | | | | | | | | bftw() implements depth-first search by appending files to a batch, then prepending the batch to the queue. When we switched to separate file/ directory queues, this was only implemented for the file queue. Unbuffered searches don't use the file queue, so they were all breadth- first in practice. This meant that iterative deepening (-S ids) was actually "iterative deepening *breadth*-first search," a horrible strategy with no advantage over regular breadth-first search. Now it performs iterative deepening *depth*-first search, which at least limits its memory consumption. Fixes: c1b16b49988ecff17ae30978ea14798d95b80018
* bftw: Let iterative deepening work depth-first when sortingTavian Barnes2023-10-121-1/+1
|
* bar: Replace volatile sig_atomic_t with actual atomicsTavian Barnes2023-10-061-8/+12
|
* alloc: Test allocation size overflowsTavian Barnes2023-10-061-2/+2
|
* bfstd: Add a thread-safe wrapper for strerror()Tavian Barnes2023-10-058-7/+63
|
* thread: Define thread_localTavian Barnes2023-10-052-0/+16
|
* config: Fold !__FreeBSD__ into BFS_USE_SYS_CAPABILITY_HTavian Barnes2023-10-052-2/+2
|
* dstring: Limit the special dchar typedef to lint buildsTavian Barnes2023-10-041-7/+2
| | | | | Clang still thinks that alignof(dstr[1]) == 2, so out of an abundance of caution, don't mess with dchar alignment in normal builds.
* thread: s/call_once/invoke_once/Tavian Barnes2023-10-033-3/+3
| | | | call_once() is a reserved identifier from C11.
* ioq: Use io_uringTavian Barnes2023-10-022-42/+288
| | | | Closes #65.
* Formatting fixesTavian Barnes2023-09-2721-99/+93
|
* bit: Fix UINTPTR_WIDTH typoTavian Barnes2023-09-261-1/+1
|
* bit: Use predefined __*_WIDTH__ macros if we canTavian Barnes2023-09-261-24/+69
|
* dstring: New dchar typedef for dynamic stringsTavian Barnes2023-09-2611-64/+85
|
* Use the new list macrosTavian Barnes2023-09-255-26/+22
|
* list: New for_[s]list() macrosTavian Barnes2023-09-251-2/+60
|
* list: Unify formattingTavian Barnes2023-09-251-16/+32
|
* list: New [S]LIST_EMPTY() macrosTavian Barnes2023-09-251-0/+18
|
* list: New [S]LIST_ITEM_INIT() macrosTavian Barnes2023-09-251-22/+52
|
* list: Use (void)(...) rather than do { ... } while (0)Tavian Barnes2023-09-251-31/+30
| | | | This makes everything usable in expression contexts.