2023-05-18 12:17:28 +00:00
|
|
|
#!/usr/bin/env sh
|
2022-03-15 18:02:04 +00:00
|
|
|
# SPDX-FileCopyrightText: 2022 Caleb La Grange <thonkpeasant@protonmail.com>
|
2023-05-18 08:35:26 +00:00
|
|
|
# SPDX-FileCopyrightText: 2023 Leah Rowe <leah@libreboot.org>
|
2022-03-15 18:02:04 +00:00
|
|
|
# SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
|
2023-08-24 00:08:08 +00:00
|
|
|
. "include/err.sh"
|
|
|
|
|
2023-05-18 08:35:26 +00:00
|
|
|
git_name="lbmkplaceholder"
|
|
|
|
git_email="placeholder@lbmkplaceholder.com"
|
|
|
|
|
|
|
|
main()
|
|
|
|
{
|
much, much stricter, more verbose error handling
lbmk is much more likely to crash now, in error conditions,
which is a boon for further auditing.
also: in "fetch", remove the downloaded program
if fail() was called.
this would also be done for gnulib, when downloading
grub, but done in such a way that gnulib goes first.
where calls to err write "ERROR" in the string, they
no longer say "ERROR" because the "err" function itself
now does that automatically.
also: listmodes/listoptions (in "lbmk") now reports an
error if no scripts and/or directories are found.
also: where a warning is given, but not an error, i've
gone through in some places and redirected the output
to stderr, not stdout
as part of error checks: running anything as root, except
for the "./build dependencies *" commands, is no longer
permitted and lbmk will throw an error
mrc downloads: debugfs output no longer redirected to /dev/null,
and stderr no longer redirected to stdout. everything is verbose.
certain non-error states are also more verbose. for example,
patch_rom in blobs/inject will now state when injection succeeds
certain actual errors(bugs) were fixed:
for example, build/release/roms now correctly prepares the blobs
hash files for a given target, containing only the files and
checksums in the list. Previously, a printf message was included.
Now, with this new code: blobutil/inject rightly verifies hashes.
doing all of this in one giant patch is cleaner
than 100 patches changing each file. even this is yet part
of a much larger audit going on in the Libreboot project.
Signed-off-by: Leah Rowe <leah@libreboot.org>
2023-08-24 19:19:41 +00:00
|
|
|
[ "$(id -u)" = "0" ] && return 0
|
|
|
|
|
2023-05-18 08:35:26 +00:00
|
|
|
if [ $# -gt 0 ]; then
|
|
|
|
if [ "${1}" = "clean" ]; then
|
2023-08-24 00:00:04 +00:00
|
|
|
clean 1> /dev/null
|
2023-05-18 08:55:40 +00:00
|
|
|
else
|
2023-08-24 00:08:08 +00:00
|
|
|
err "unsupported argument, \"${1}\""
|
2023-05-18 08:35:26 +00:00
|
|
|
fi
|
|
|
|
else
|
2023-08-24 00:00:04 +00:00
|
|
|
set_placeholders 1> /dev/null
|
2023-05-18 08:41:00 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
set_placeholders()
|
|
|
|
{
|
|
|
|
set_git_credentials
|
|
|
|
|
|
|
|
# Check coreboot as well to prevent errors during building
|
2023-08-24 00:08:08 +00:00
|
|
|
[ -d coreboot ] || return 0
|
2023-05-18 08:42:06 +00:00
|
|
|
for x in coreboot/*; do
|
2023-08-24 00:08:08 +00:00
|
|
|
[ -d "${x}" ] || continue
|
2023-08-24 15:37:40 +00:00
|
|
|
[ -e "${x}/.git" ] || continue
|
2023-05-18 08:49:26 +00:00
|
|
|
(
|
2023-05-18 08:42:06 +00:00
|
|
|
cd "${x}"
|
|
|
|
set_git_credentials
|
2023-05-18 08:49:26 +00:00
|
|
|
)
|
2023-05-18 08:42:06 +00:00
|
|
|
done
|
2023-05-18 08:35:26 +00:00
|
|
|
}
|
|
|
|
|
2023-05-18 08:41:00 +00:00
|
|
|
set_git_credentials()
|
2023-05-18 08:35:26 +00:00
|
|
|
{
|
2022-11-21 02:42:31 +00:00
|
|
|
# Check if username and or email is set.
|
|
|
|
if ! git config user.name || git config user.email ; then
|
2023-08-24 00:08:08 +00:00
|
|
|
git config user.name || git config user.name "${git_name}" || \
|
|
|
|
err "cannot set local git user.name"
|
|
|
|
git config user.email || git config user.email "${git_email}" \
|
|
|
|
|| err "cannot set local git user.email"
|
2022-11-21 02:42:31 +00:00
|
|
|
fi
|
2022-03-15 18:02:04 +00:00
|
|
|
}
|
|
|
|
|
2023-05-18 08:35:26 +00:00
|
|
|
clean()
|
2023-05-18 08:44:11 +00:00
|
|
|
{
|
|
|
|
unset_placeholders
|
|
|
|
|
2023-08-24 00:08:08 +00:00
|
|
|
[ -d coreboot ] || return 0
|
2023-05-18 08:44:11 +00:00
|
|
|
for x in coreboot/*; do
|
2023-08-24 00:08:08 +00:00
|
|
|
[ -d "${x}" ] || continue
|
2023-08-24 15:37:40 +00:00
|
|
|
[ -e "${x}/.git" ] || continue
|
2023-05-18 08:49:26 +00:00
|
|
|
(
|
2023-05-18 08:44:11 +00:00
|
|
|
cd "${x}"
|
|
|
|
unset_placeholders
|
2023-05-18 08:49:26 +00:00
|
|
|
)
|
2023-05-18 08:44:11 +00:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
unset_placeholders()
|
2023-05-18 08:35:26 +00:00
|
|
|
{
|
|
|
|
if [ "$(git config user.name)" = "${git_name}" ]; then
|
2023-08-24 00:08:08 +00:00
|
|
|
git config --unset user.name || \
|
|
|
|
err "cannot unset local git user.name"
|
2022-03-15 18:02:04 +00:00
|
|
|
fi
|
|
|
|
|
2023-05-18 08:35:26 +00:00
|
|
|
if [ "$(git config user.email)" = "${git_email}" ]; then
|
2023-08-24 00:08:08 +00:00
|
|
|
git config --unset user.email || \
|
|
|
|
err "cannot unset local git user.email"
|
2022-03-15 18:02:04 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-05-18 08:55:40 +00:00
|
|
|
main $@
|