summaryrefslogtreecommitdiffstats
path: root/eval.c
Commit message (Collapse)AuthorAgeFilesLines
* Use two newlines for all pre-eval warningsTavian Barnes2020-11-091-1/+1
|
* eval: Fix the status bar to only print the parent againTavian Barnes2020-11-041-5/+7
|
* eval: Make a crude attempt to handle double-width chars in the status barTavian Barnes2020-11-041-11/+49
|
* Enable -Wsign-compare to catch bugs like 726d7801Tavian Barnes2020-11-041-5/+5
|
* New -status option to display a status barTavian Barnes2020-11-031-11/+100
|
* expr, eval: Clean up header dependenciesTavian Barnes2020-10-061-0/+1
|
* diag: New bfs_perror() functionTavian Barnes2020-10-051-6/+6
|
* util: Don't rely on bftwTavian Barnes2020-09-301-1/+1
| | | | And rename format_mode() to xstrmode() while I'm at it.
* Rename struct cmdline to bfs_ctxTavian Barnes2020-09-271-66/+80
| | | | | The API remains similar, with some added accessor functions for lazy initialization of the pwcache and mtab.
* stat: Rename bfs_stat_flag to _flagsTavian Barnes2020-09-181-2/+2
| | | | Flags enums should be plural.
* Don't call stat() just to determine symbolic lengthsTavian Barnes2020-09-181-5/+3
| | | | | | | 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.
* Implement -xattrnameTavian Barnes2020-08-131-0/+13
| | | | From macOS find.
* bftw: Make some flag names more explicitTavian Barnes2020-07-291-6/+6
|
* bftw: Rename bftw_typeflag to bftw_type, and make it not a bitmaskTavian Barnes2020-07-291-37/+35
|
* eval: Fix an assertion failure with -D search -sTavian Barnes2020-06-161-0/+1
|
* eval: Fix a segfault with -D search -S edsTavian Barnes2020-06-161-0/+1
|
* Treat -nohidden like -exclude -hiddenTavian Barnes2020-06-071-12/+0
| | | | Fixes #30.
* Implement -exclude, a special form for convenient exclusionsTavian Barnes2020-06-071-0/+5
| | | | Fixes #8.
* diag: Unify debug printingTavian Barnes2020-06-021-14/+14
|
* pwcache: Rename from passwd.[ch]Tavian Barnes2020-04-221-1/+1
|
* passwd: Cache the user/group tablesTavian Barnes2020-02-291-22/+7
| | | | | | | | | | | | | | | | | | | | | | This is a significant optimization for conditions that need these tables: Benchmark #1: ./bfs ~/code/linux -nouser >/dev/null Time (mean ± σ): 232.0 ms ± 2.5 ms [User: 44.3 ms, System: 185.0 ms] Range (min … max): 228.7 ms … 238.7 ms 12 runs Benchmark #2: ./bfs-1.6 ~/code/linux -nouser >/dev/null Time (mean ± σ): 1.050 s ± 0.012 s [User: 544.2 ms, System: 500.0 ms] Range (min … max): 1.025 s … 1.063 s 10 runs Benchmark #3: find ~/code/linux -nouser >/dev/null Time (mean ± σ): 1.040 s ± 0.012 s [User: 533.6 ms, System: 500.6 ms] Range (min … max): 1.017 s … 1.054 s 10 runs Summary './bfs ~/code/linux -nouser >/dev/null' ran 4.48 ± 0.07 times faster than 'find ~/code/linux -nouser >/dev/null' 4.52 ± 0.07 times faster than './bfs-1.6 ~/code/linux -nouser >/dev/null'
* eval: Irregular files aren't emptyTavian Barnes2020-02-141-1/+1
| | | | | GNU find's -empty returns false for devices, sockets, etc., even though their st_size is 0. Match that behaviour.
* time: Split out time-related functions from utilTavian Barnes2020-02-131-0/+1
|
* Update copyright datesTavian Barnes2020-01-071-1/+1
|
* eval: For -ls, print a + if a file has ACLsTavian Barnes2020-01-071-1/+2
|
* darray: New dynamic array libraryTavian Barnes2019-08-291-1/+2
|
* Make -mount and -xdev do different thingsTavian Barnes2019-07-041-0/+1
| | | | | | | | | POSIX now says -mount should skip the whole mount point, while -xdev should only skip its descendents. C.f. http://austingroupbugs.net/view.php?id=1133 C.f. https://savannah.gnu.org/bugs/?42318 C.f. https://savannah.gnu.org/bugs/?54745
* bftw: Remove BFTW_SKIP_SIBLINGSTavian Barnes2019-06-251-7/+6
| | | | | It's not used by bfs, and it's difficult to support in all search strategies.
* util: Filter out . and .. in xreaddir()Tavian Barnes2019-06-251-25/+8
|
* eval: Get rid of a level of indirection for quitTavian Barnes2019-06-161-13/+10
|
* Implement an iterative deepening mode (-ids)Tavian Barnes2019-05-291-1/+2
|
* Implement a depth-first mode (-dfs)Tavian Barnes2019-05-281-1/+14
|
* bftw: Visit multiple roots breadth-firstTavian Barnes2019-05-281-36/+33
| | | | This makes `bfs a b` treat `a` and `b` as siblings.
* Implement -xattr predicateTavian Barnes2019-05-241-0/+13
|
* fsade: Refactor the POSIX.1e abstractionsTavian Barnes2019-05-241-3/+15
| | | | | | | Since we're going to want to abstract more things that aren't part of POSIX.1e (like xattrs) in a similar way, let's give this a more generic name. And while we're at it, give it some more precise error reporting, and add some tests.
* color: Don't stat() if we don't need toTavian Barnes2019-05-051-7/+1
|
* bftw: Pass a const struct BFTW * to the callbackTavian Barnes2019-05-051-12/+12
|
* bftw: Add a caching stat() API to struct BFTWTavian Barnes2019-05-041-134/+75
|
* stat: Unify the flags argumentsTavian Barnes2019-05-041-16/+12
|
* Release 1.41.4Tavian Barnes2019-04-151-1/+1
|
* eval: Fix -unique with -depthTavian Barnes2019-03-071-1/+1
|
* bftw: Work around d_type being wrong for bind mounts on LinuxTavian Barnes2019-03-061-7/+14
| | | | | | C.f. https://savannah.gnu.org/bugs/?54913 C.f. https://lkml.org/lkml/2019/2/11/2027 Fixes https://github.com/tavianator/bfs/issues/37
* bftw: Switch from taking separate parameters to a parameters structTavian Barnes2019-03-061-6/+18
|
* parse: Use a trie to hold currently open filesTavian Barnes2019-03-061-4/+2
|
* trie: Revamp the API to support mappingsTavian Barnes2019-03-041-5/+8
|
* Implement -uniqueTavian Barnes2019-03-011-0/+43
| | | | Closes #48
* Add some documentation commentsTavian Barnes2019-02-091-0/+4
|
* Fix -nouser/-nogroup error handlingTavian Barnes2019-02-061-2/+20
| | | | | | | | | | The proper way to check for nonexistent users/groups is to set errno to 0 before the get{grg,pwu}id() call, and check it afterwards. On doing this, it becomes obvious that the call can fail if bftw() is using all the available FDs, so give them some ephemeral FDs. It would be ideal to read the user/group table only once, but this fixes the bug for now.
* eval: Fix wrong colors in error messagesTavian Barnes2019-02-011-45/+72
| | | | | When reporting an error, we should try to stat the file first so the message can have the right colors.
* parse: Allow multiple comma-separated debug flagsTavian Barnes2019-01-111-8/+10
|