Page MenuHomeFreeBSD

pkgbase: pass --recurse-submodules to `git ls-files`
ClosedPublic

Authored by emaste on Dec 9 2023, 3:21 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 21, 10:30 AM
Unknown Object (File)
Fri, Jan 10, 5:34 AM
Unknown Object (File)
Dec 11 2024, 6:22 PM
Unknown Object (File)
Nov 24 2024, 4:11 PM
Unknown Object (File)
Nov 22 2024, 6:16 AM
Unknown Object (File)
Nov 20 2024, 6:17 AM
Unknown Object (File)
Nov 18 2024, 9:14 PM
Unknown Object (File)
Nov 11 2024, 2:50 AM
Subscribers

Details

Summary
When generating source packages.  Although submodules are not used by
FreeBSD itself they may be used by downstream projects.  By default
`git ls-files` just emits the directory name, which resulted in:

    pkg: pkg_checksum_hash_sha256_file(read failed): Is a directory

Passing --recurse-submodules lists all of the files in each submodule,
and has no effect when submodules are not in use.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

emaste requested review of this revision.Dec 9 2023, 3:21 AM
emaste created this revision.
This revision is now accepted and ready to land.Dec 9 2023, 3:53 AM

Although this change is fine, the 'harmless' bit needs a small caveat.

There's a few projects I use (MAME, QEMU and EDK2) that have submodules, but don't need the full recursive submodules to build. And you can get in trouble if you do all your submodule commands recursively, especially when updating them recursively and/or bisecting problems in the parent repo. It's likely fine for ls-files, but other operations (like cloning or fetching) should be approached with some caution.