2021-11-18 16:02:53 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# Compute the dependencies (direct and transitive) of an object
|
|
|
|
# This is used to collect all objects needed to link a program.
|
|
|
|
|
|
|
|
# Bail out when .d files are missing
|
|
|
|
test -f "${1%.o}.d" || exit 1
|
|
|
|
|
|
|
|
# Check whether $1 contains substring $2
|
|
|
|
contains(){ test "${1#*$2}" != "$1"; }
|
|
|
|
|
2023-03-30 11:05:54 +02:00
|
|
|
# Walk the dependency graph (consisting of the set of all .d files)
|
2021-11-18 16:02:53 +01:00
|
|
|
# and output the visited nodes (objects).
|
|
|
|
walk_dag(){
|
|
|
|
while read -r line; do
|
|
|
|
# skip the first line (file own name)
|
|
|
|
contains "$line" ': ' && continue
|
2022-04-29 01:52:50 +02:00
|
|
|
# only look up object files
|
|
|
|
contains "$line" '.o ' || continue
|
2021-11-18 16:02:53 +01:00
|
|
|
line="${line% \\}"
|
|
|
|
contains "$visited" "$line" && continue
|
|
|
|
visited="$line:$visited"
|
|
|
|
printf '%s ' "$line"
|
|
|
|
# whether the node is a leaf
|
|
|
|
test "$(wc -l < "${line%.o}.d")" -gt 1 && walk_dag < "${line%.o}.d"
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
printf '%s ' "$1" # the object itself
|
|
|
|
walk_dag < "${1%.o}.d"
|