Page MenuHomeFreeBSD

preserve: run a command and replace its output only if it has changed
Needs ReviewPublic

Authored by des on Mar 29 2023, 5:58 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 14, 5:43 PM
Unknown Object (File)
Dec 22 2024, 9:09 AM
Unknown Object (File)
Dec 19 2024, 8:18 AM
Unknown Object (File)
Dec 9 2024, 1:43 AM
Unknown Object (File)
Nov 27 2024, 5:13 PM
Unknown Object (File)
Oct 31 2024, 2:51 AM
Unknown Object (File)
Sep 26 2024, 11:28 PM
Unknown Object (File)
Sep 25 2024, 3:52 PM
This revision needs review, but there are no reviewers specified.

Details

Reviewers
None
Summary

Introduce a new utility, preserve, which can be used to wrap any command that produces a single output file to ensure that the file is untouched unless the output has genuinely changed.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 50666
Build 47557: arc lint + arc unit

Event Timeline

des requested review of this revision.Mar 29 2023, 5:58 PM
jrtc27 added inline comments.
usr.bin/preserve/preserve.c
86

I would expect a vflag-guarded message here

196

This loses the fact that the child was signalled.

212

Why exit rather than return?

usr.bin/preserve/preserve.c
196

Kind of. The exit status will still be 128 + signal. Getting it 100% right is depressingly difficult.

212

Why return rather than exit?

usr.bin/preserve/preserve.c
86

Good catch. Note that this shouldn't occur though, unless we lost a race.

des marked an inline comment as done.Mar 29 2023, 6:34 PM

Try to deal with signals.

des marked an inline comment as done.Mar 29 2023, 6:39 PM
des marked an inline comment as done.

I have wanted a utility that does exactly this. install -C does something similar, but has other stuff I don’t want. So far I just end up scripting cmp(1) to do the check.

Would it make sense to add a -o flag to cmp(1) to provide this behavior there? It would write file1 to file2 if the contents differ.

Would it make sense to add a -o flag to cmp(1) to provide this behavior there? It would write file1 to file2 if the contents differ.

I don't think so. It wouldn't let you do make TOOL="preserve tool" like this does.