all repos — nixfiles @ a2d6adfa523a32e1f8c184602eec555365bc02c9

System and user configuration, managed by nix and home-manager

fish: fix newest/oldest

before:
 - errors if arg was not a directory
 - hours and minutes were incorrectly separated, making sort
 inaccurate
 - `newest` would show the oldest file as reverse is handled per-key
Alan Pearce alan@alanpearce.eu
Mon, 20 May 2024 20:29:46 +0200
commit

a2d6adfa523a32e1f8c184602eec555365bc02c9

parent

d2db2799c625d163bbe54500854fc73ec350e574

2 files changed, 12 insertions(+), 8 deletions(-)

jump to
M user/settings/fish/functions/newest.fishuser/settings/fish/functions/newest.fish
@@ -4,9 +4,11 @@ echo "Need at least one path"         return 1
     end
     for arg in $argv
-        fd --hidden --print0 --max-depth 1 . $arg |
-            bfs -files0-from - \( -name .git -prune \) -o \( -printf '%TY%Tm%Td%TR %TF %h/%f\n' \) |
-            sort --reverse --key 1n,1 | head --lines 1 |
-            cut -d ' ' -f 2,3
+        if test -d $arg
+            fd --hidden --print0 --max-depth 1 . $arg |
+                bfs -files0-from - \( -name .git -prune \) -o \( -printf '%TY%Tm%Td%TH%TM %TF %h/%f\n' \) |
+                sort --key 1nr,1 | head --lines 1 |
+                cut -d ' ' -f 2,3
+        end
     end
 end
M user/settings/fish/functions/oldest.fishuser/settings/fish/functions/oldest.fish
@@ -4,9 +4,11 @@ echo "Need at least one path"         return 1
     end
     for arg in $argv
-        fd --hidden --print0 --max-depth 1 . $arg |
-            bfs -files0-from - \( -name .git -prune \) -o \( -printf '%TY%Tm%Td%TR %TF %h/%f\n' \) |
-            sort --key 1n,1 | head --lines 1 |
-            cut -d ' ' -f 2,3
+        if test -d $arg
+            fd --hidden --print0 --max-depth 1 . $arg |
+                bfs -files0-from - \( -name .git -prune \) -o \( -printf '%TY%Tm%Td%TH%TM %TF %h/%f\n' \) |
+                sort --key 1n,1 | head --lines 1 |
+                cut -d ' ' -f 2,3
+        end
     end
 end