mirror of
https://github.com/LibreELEC/LibreELEC.tv.git
synced 2025-07-28 05:06:43 +00:00
config/functions: eliminate unecessary dashboard flock()
This commit is contained in:
parent
7e99243489
commit
b272bcb999
@ -1295,9 +1295,11 @@ pkg_lock_status() {
|
|||||||
[ -n "${msg}" ] && line+=" (${msg})"
|
[ -n "${msg}" ] && line+=" (${msg})"
|
||||||
|
|
||||||
echo "${line}" >>"${THREAD_CONTROL}/history"
|
echo "${line}" >>"${THREAD_CONTROL}/history"
|
||||||
) 94>"${THREAD_CONTROL}/locks/.history"
|
|
||||||
|
|
||||||
[ "${DASHBOARD}" != "no" ] && update_dashboard "${status}" "${pkg}" "${task}" "${msg}"
|
if [ "${DASHBOARD}" != "no" ]; then
|
||||||
|
update_dashboard "${status}" "${pkg}" "${task}" "${msg}"
|
||||||
|
fi
|
||||||
|
) 94>"${THREAD_CONTROL}/locks/.history"
|
||||||
|
|
||||||
if [ "${status}" = "LOCKED" ]; then
|
if [ "${status}" = "LOCKED" ]; then
|
||||||
echo "${PARALLEL_SEQ}" > "${THREAD_CONTROL}/locks/${pkg}.${task}.failed"
|
echo "${PARALLEL_SEQ}" > "${THREAD_CONTROL}/locks/${pkg}.${task}.failed"
|
||||||
@ -1314,47 +1316,43 @@ update_dashboard() {
|
|||||||
local line sedline preamble num elapsed projdevarch
|
local line sedline preamble num elapsed projdevarch
|
||||||
local boldred boldgreen boldyellow endcolor
|
local boldred boldgreen boldyellow endcolor
|
||||||
|
|
||||||
(
|
[ -n "${MTJOBID}" ] && sedline=$((MTJOBID + 2)) || sedline=1
|
||||||
flock --exclusive 97
|
|
||||||
|
|
||||||
[ -n "${MTJOBID}" ] && sedline=$((MTJOBID + 2)) || sedline=1
|
num=$(cat "${THREAD_CONTROL}/status" | wc -l)
|
||||||
|
while [ ${num} -lt ${sedline} ]; do echo "" >>"${THREAD_CONTROL}/status"; num=$((num + 1)); done
|
||||||
|
|
||||||
num=$(cat "${THREAD_CONTROL}/status" | wc -l)
|
num=$(($(cat "${THREAD_CONTROL}/progress.prev") + 1))
|
||||||
while [ ${num} -lt ${sedline} ]; do echo "" >>"${THREAD_CONTROL}/status"; num=$((num + 1)); done
|
projdevarch="${PROJECT}/"
|
||||||
|
[ -n "${DEVICE}" ] && projdevarch+="${DEVICE}/"
|
||||||
|
projdevarch+="${TARGET_ARCH}"
|
||||||
|
TZ=UTC0 printf -v elapsed "%(%H:%M:%S)T" $(($(date +%s) - MTBUILDSTART))
|
||||||
|
printf -v preamble "%s Dashboard (%s) - %d of %d jobs completed, %s elapsed" "${DISTRONAME}" "${projdevarch}" ${num} ${MTMAXJOBS} "${elapsed}"
|
||||||
|
printf -v preamble "%b%-105s %s" "\e[2J\e[0;0H" "${preamble//\//\\/}" "$(date "+%Y-%m-%d %H:%M:%S")"
|
||||||
|
|
||||||
num=$(($(cat "${THREAD_CONTROL}/progress.prev") + 1))
|
# Only update the header when caller is not a worker thread
|
||||||
projdevarch="${PROJECT}/"
|
if [ -z "${MTJOBID}" ]; then
|
||||||
[ -n "${DEVICE}" ] && projdevarch+="${DEVICE}/"
|
sed -e "1s/.*/${preamble}/" -i "${THREAD_CONTROL}/status"
|
||||||
projdevarch+="${TARGET_ARCH}"
|
else
|
||||||
TZ=UTC0 printf -v elapsed "%(%H:%M:%S)T" $(($(date +%s) - MTBUILDSTART))
|
if [ "${DISABLE_COLORS}" != "yes" ]; then
|
||||||
printf -v preamble "%s Dashboard (%s) - %d of %d jobs completed, %s elapsed" "${DISTRONAME}" "${projdevarch}" ${num} ${MTMAXJOBS} "${elapsed}"
|
boldred="\e[1;31m"
|
||||||
printf -v preamble "%b%-105s %s" "\e[2J\e[0;0H" "${preamble//\//\\/}" "$(date "+%Y-%m-%d %H:%M:%S")"
|
boldgreen="\e[1;32m"
|
||||||
|
boldyellow="\e[1;33m"
|
||||||
|
white="\e[0;37m"
|
||||||
|
endcolor="\e[0m"
|
||||||
|
|
||||||
# Only update the header when caller is not a worker thread
|
case "${status}" in
|
||||||
if [ -z "${MTJOBID}" ]; then
|
IDLE) color="${white}";;
|
||||||
sed -e "1s/.*/${preamble}/" -i "${THREAD_CONTROL}/status"
|
STALLED) color="${boldyellow}";;
|
||||||
else
|
MUTEX/W) color="${boldyellow}";;
|
||||||
if [ "${DISABLE_COLORS}" != "yes" ]; then
|
FAILED ) color="${boldred}";;
|
||||||
boldred="\e[1;31m"
|
*) color="${boldgreen}";;
|
||||||
boldgreen="\e[1;32m"
|
esac
|
||||||
boldyellow="\e[1;33m"
|
|
||||||
white="\e[0;37m"
|
|
||||||
endcolor="\e[0m"
|
|
||||||
|
|
||||||
case "${status}" in
|
|
||||||
IDLE) color="${white}";;
|
|
||||||
STALLED) color="${boldyellow}";;
|
|
||||||
MUTEX/W) color="${boldyellow}";;
|
|
||||||
FAILED ) color="${boldred}";;
|
|
||||||
*) color="${boldgreen}";;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
printf -v line "[%02d\/%0*d] %b%-7s%b %-7s %-35s" ${MTJOBID} ${#MTMAXJOBS} ${PARALLEL_SEQ:-0} "${color}" "${status//\//\\/}" "${endcolor}" "${task}" "${pkg}"
|
|
||||||
[ -n "${msg}" ] && line+=" ${msg//\//\\/}"
|
|
||||||
sed -e "1s/.*/${preamble}/;${sedline}s/.*/${line}/" -i "${THREAD_CONTROL}/status"
|
|
||||||
fi
|
fi
|
||||||
) 97>"${THREAD_CONTROL}/locks/.status"
|
|
||||||
|
printf -v line "[%02d\/%0*d] %b%-7s%b %-7s %-35s" ${MTJOBID} ${#MTMAXJOBS} ${PARALLEL_SEQ:-0} "${color}" "${status//\//\\/}" "${endcolor}" "${task}" "${pkg}"
|
||||||
|
[ -n "${msg}" ] && line+=" ${msg//\//\\/}"
|
||||||
|
sed -e "1s/.*/${preamble}/;${sedline}s/.*/${line}/" -i "${THREAD_CONTROL}/status"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Thread concurrency helpers to avoid concurrency issues with some code,
|
# Thread concurrency helpers to avoid concurrency issues with some code,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user