Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | bfstd: Only free the locale if we dup'd it successfully | Tavian Barnes | 2023-10-26 | 1 | -3/+3 | |
| | ||||||
* | ci: Run tests in parallel on macOS and FreeBSD | Tavian Barnes | 2023-10-23 | 1 | -2/+3 | |
| | ||||||
* | tests/bfs/help: Fix exit status | Tavian Barnes | 2023-10-23 | 1 | -4/+4 | |
| | ||||||
* | tests/bfs/help: Use ... && fail instead of ! ... | Tavian Barnes | 2023-10-23 | 2 | -5/+4 | |
| | | | | ! false doesn't trigger an error with set -e. | |||||
* | tests/bfs/printf_color: Fix race condition | Tavian Barnes | 2023-10-23 | 2 | -1/+2 | |
| | | | | | Invoking bfs in the top directory can lead it to explore other tests' scratch directories, so explicitly exclude them. | |||||
* | tests: Document -j | Tavian Barnes | 2023-10-23 | 1 | -21/+20 | |
| | ||||||
* | tests: Clean up verbose logging a bit | Tavian Barnes | 2023-10-23 | 1 | -20/+36 | |
| | ||||||
* | tests: Fix Bash 3 compatibility | Tavian Barnes | 2023-10-23 | 7 | -37/+47 | |
| | ||||||
* | tests: Run test cases in parallel | Tavian Barnes | 2023-10-23 | 3 | -16/+64 | |
| | ||||||
* | tests: Use test-specific scratch directories | Tavian Barnes | 2023-10-22 | 77 | -368/+330 | |
| | ||||||
* | tests: Fix column detection with redirected stderr | Tavian Barnes | 2023-10-20 | 1 | -1/+1 | |
| | ||||||
* | tests/color: Remove some useless cats | Tavian Barnes | 2023-10-20 | 4 | -53/+50 | |
| | ||||||
* | tests: Use xtouch to create the whole deep tree at once | Tavian Barnes | 2023-10-20 | 1 | -15/+6 | |
| | ||||||
* | tests/xtouch: Recover from ENAMETOOLONG | Tavian Barnes | 2023-10-20 | 1 | -45/+84 | |
| | ||||||
* | tests: Don't unset array[-1] | Tavian Barnes | 2023-10-19 | 1 | -6/+7 | |
| | | | | This was only added in Bash 4.3 which is too new for macOS. | |||||
* | tests: Refactor implementation into separate files | Tavian Barnes | 2023-10-19 | 13 | -823/+906 | |
| | ||||||
* | tests: Update bash coding style | Tavian Barnes | 2023-10-19 | 1 | -32/+32 | |
| | ||||||
* | tests: Clean up colorization | Tavian Barnes | 2023-10-19 | 1 | -76/+102 | |
| | ||||||
* | tests: Use the ERR trap to print the failing command | Tavian Barnes | 2023-10-19 | 1 | -4/+46 | |
| | ||||||
* | tests: Fix uses of $? with set -e | Tavian Barnes | 2023-10-19 | 1 | -10/+12 | |
| | ||||||
* | tests: New defer function | Tavian Barnes | 2023-10-19 | 18 | -34/+54 | |
| | ||||||
* | tests: Rename --noclean -> --no-clean | Tavian Barnes | 2023-10-19 | 1 | -3/+3 | |
| | ||||||
* | bench: Account for tailfin's at-exit -> defer rename | Tavian Barnes | 2023-10-19 | 1 | -2/+2 | |
| | ||||||
* | wordesc: Don't allow braces in bare words | Tavian Barnes | 2023-10-18 | 1 | -1/+1 | |
| | | | | Things like {a,b} should be quoted to avoid brace expansion. | |||||
* | parse: Set BFTW_WHITEOUTS when parsing -type w | Tavian Barnes | 2023-10-17 | 3 | -0/+105 | |
| | ||||||
* | bftw: New flag to control whiteout visibility | Tavian Barnes | 2023-10-17 | 3 | -2/+19 | |
| | ||||||
* | dir: New flag to control whiteout visibility | Tavian Barnes | 2023-10-17 | 2 | -3/+13 | |
| | ||||||
* | dir: Fix FreeBSD union mounts | Tavian Barnes | 2023-10-17 | 5 | -8/+74 | |
| | ||||||
* | dir: Add a flags parameter to bfs_opendir() | Tavian Barnes | 2023-10-17 | 6 | -21/+45 | |
| | ||||||
* | tests: Move closed_std* tests out of the POSIX group | Tavian Barnes | 2023-10-14 | 6 | -2/+8 | |
| | | | | | | | | | | | | | POSIX actually says > If the utility would be executed with file descriptor 0, 1, or 2 > closed, implementations may execute the utility with the file > descriptor open to an unspecified file. So we're not guaranteed to be able to detect the situation in the first place. Add a best-effort check for these platforms and skip the test. Link: https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_09_01_01 | |||||
* | dir: Fix Android build | Tavian Barnes | 2023-10-14 | 1 | -1/+1 | |
| | | | | Android doesn't provide a getdents() wrapper, so use the syscall. | |||||
* | docs: Add a list of related utilities | Tavian Barnes | 2023-10-13 | 1 | -0/+42 | |
| | ||||||
* | tests: Always create the scratch directory | Tavian Barnes | 2023-10-13 | 1 | -0/+2 | |
| | | | | | | | | | | | | | | | | Otherwise, some tests that try to check for flag support like invoke_bfs scratch -quit -xattr || skip can be accidentally skipped if ./scratch doesn't exist yet: $ ./tests/tests.sh bsd/xattr tests skipped: 1 After this patch, we get the expected $ ./tests/tests.sh bsd/xattr tests passed: 1 | |||||
* | Merge tag '3.0.4' | Tavian Barnes | 2023-10-12 | 5 | -4/+16 | |
|\ | ||||||
| * | Release 3.0.43.0.4 | Tavian Barnes | 2023-10-12 | 3 | -2/+14 | |
| | | ||||||
| * | tests: Don't crash if unbuffer isn't installed | Tavian Barnes | 2023-10-12 | 1 | -1/+1 | |
| | | ||||||
| * | bfstd: Actually use the copied locale | Tavian Barnes | 2023-10-12 | 1 | -1/+1 | |
| | | | | | | | | This fixes a segfault in xstrerror() when using musl. | |||||
* | | build: Re-enable liburing | Tavian Barnes | 2023-10-12 | 1 | -1/+1 | |
|/ | | | | This reverts commit 735a2979a37251dc447274aa888ad77ded126457. | |||||
* | Release 3.0.33.0.3 | Tavian Barnes | 2023-10-12 | 3 | -13/+5 | |
| | ||||||
* | build: Disable liburing for now | Tavian Barnes | 2023-10-12 | 1 | -1/+1 | |
| | | | | liburing will be enabled for the next feature release. | |||||
* | docs: Start writing the 3.1 changelog | Tavian Barnes | 2023-10-12 | 1 | -0/+33 | |
| | ||||||
* | bench: Look for ./bfs if ./bin/bfs doesn't exist | Tavian Barnes | 2023-10-12 | 1 | -1/+5 | |
| | ||||||
* | bench: Check for bfs -j support before using it | Tavian Barnes | 2023-10-12 | 1 | -3/+13 | |
| | ||||||
* | bftw: Make sure we don't close a directory while we unwrap it | Tavian Barnes | 2023-10-12 | 1 | -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_UNWRAPDIR | Tavian Barnes | 2023-10-12 | 1 | -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 nodes | Tavian Barnes | 2023-10-12 | 2 | -21/+46 | |
| | ||||||
* | diag: Move enum debug_flags out of ctx.h | Tavian Barnes | 2023-10-12 | 5 | -53/+55 | |
| | ||||||
* | bftw: Don't force buffering for parallel dfs | Tavian Barnes | 2023-10-12 | 1 | -5/+30 | |
| | ||||||
* | bftw: Fix unbuffered depth-first searches | Tavian Barnes | 2023-10-12 | 1 | -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 sorting | Tavian Barnes | 2023-10-12 | 1 | -1/+1 | |
| |