if [ `wc -l < ${TMPDIR}/moved.info` -eq 0 ]
then
fileedit_add_a_line_if_new "$origin" "${DBDIR}/obsolete_ports"
+ fileedit_rm_a_line "$origin" "${DBDIR}/moved_ports"
if [ -n "$recursedb_in" ]
then
message_echo "${DEPTH_INDEX} ===> Disappeared port (MOVED broken?)"
then
message_echo "${DEPTH_INDEX} ===> Moved to $origin_new at $date_moved because \"$why_moved\""
fileedit_add_a_line_if_new "$origin" "${TMPDIR}/database_build_convert_and_register_origin_if_obsolete:origins_old"
+ fileedit_add_a_line_if_new "$origin" "${DBDIR}/moved_ports"
+ fileedit_rm_a_line "$origin" "${DBDIR}/obsolete_ports"
database_build_convert_and_register_origin_if_obsolete "$origin_new" "${TMPDIR}/MOVED.DB" || return 1
else
message_echo "${DEPTH_INDEX} ===> Deleted at $date_moved because \"$why_moved\""
fileedit_add_a_line_if_new "$origin" "${DBDIR}/obsolete_ports"
+ fileedit_rm_a_line "$origin" "${DBDIR}/moved_ports"
return 1
fi
fi
origin=$1
dbdir=${DBDIR}/requires/$origin
[ -d "$dbdir" ] || dbdir=${DBDIR}/conf/each_port/$origin
- cat "$dbdir/MENV.conf" 2> /dev/null || :
+ cat "$dbdir/MENV.conf" 2> /dev/null | tr '\n' ' '
}
# ============= Execute make command for building the temporary database =============
# ============= Set up a temporary database node for the replaced/moved information of a port =============
database_build_setup_replace_node ()
{
- local origin_orig origin_trial origin dbpath
+ local origin_orig portoption_before portoption_after origin_trial origin dbpath tmp_msg
origin_orig=$1
+ portoption_before=$2
+ portoption_after=$3
dbpath=${DBDIR}/replace/$origin_orig
+ tmp_msg=${TMPDIR}/database_build_setup_replace_node:meg
if [ ! -e "$dbpath/complete_as_node" ]
then
rm -rf "$dbpath"
fi >> $dbpath/message
fi
fi
- # Configure the port option to determine the true flavor
- database_build_determine_port_option "$origin_trial"
- # Get the true flavor to determine the flavored port origin
- origin=`database_build_determine_flavored_origin "$origin_trial"`
- if [ "x$origin_trial" != "x$origin" ]
+ cat "$dbpath/message" 2> /dev/null || :
+ if [ -n "$origin_trial" ]
then
- if [ -n "$origin" ]
+ database_build_make "$origin_trial" showconfig > $portoption_before 2> /dev/null || :
+ database_build_determine_port_option "$origin_trial"
+ database_build_make "$origin_trial" showconfig > $portoption_after 2> /dev/null || :
+ origin=`database_build_determine_flavored_origin "$origin_trial"`
+ if [ "x$origin_trial" != "x$origin" ]
then
- message_echo "${DEPTH_INDEX} ===> Transferred to $origin"
- else
- fileedit_add_a_line_if_new "$origin" "${DBDIR}/obsolete_ports"
- message_echo "${DEPTH_INDEX} ===> Lost (Something is wrong!)"
- fi
+ if [ -n "$origin" ]
+ then
+ message_echo "${DEPTH_INDEX} ===> Transferred to $origin"
+ else
+ fileedit_add_a_line_if_new "$origin" "${DBDIR}/obsolete_ports"
+ message_echo "${DEPTH_INDEX} ===> Lost (Something is wrong!)"
+ fi
+ fi > $tmp_msg
+ cat "$tmp_msg" >> $dbpath/message
+ else
+ origin=
fi
[ "x$origin_orig" = "x$origin" ] || echo "$origin" > $dbpath/origin
+ cat "$tmp_msg" 2> /dev/null || :
touch "$dbpath/complete_as_node"
+ else
+ cat "$dbpath/message" 2> /dev/null || :
fi
- cat "$dbpath/message" 2> /dev/null || :
}
# ============= Get the inspected level for a port with the current option settings =============
inspected_level=`database_build_get_inspected_level "$origin_actual" "$origin_dependent"`
{
cat "${DBDIR}/ports.inspected.${inspected_level}.list" || :
+ cat "${DBDIR}/moved_ports" || :
cat "${DBDIR}/obsolete_ports" || :
} 2> /dev/null | grep -q -Fx "$origin_actual" || return
fileedit_rm_a_line "$origin" "${DBDIR}/stage.loop_list/ports_to_inspect.remain"
# ============= Get the true flavor to determine the flavored port origin =============
database_build_determine_flavored_origin ()
{
- local origin origin_unflavored flavor_trial flavor
+ local origin origin_unflavored flavor_trial origin_trial flavors_ptn flavor
origin=$1
origin_unflavored=`pkgsys_get_unflavored_origin "$origin"`
flavor_trial=`pkgsys_get_flavor_from_origin "$origin"`
if [ -n "$flavor_trial" ]
then
flavors_ptn="^("`database_build_make "$origin" -V FLAVORS 2> /dev/null | sed -E 's/[[:space:]]+/|/g'`")$"
- echo "$flavor_trial" | grep -qE "$flavors_ptn" || origin_trial=$origin_unflavored
+ echo "$flavor_trial" | grep -qE "$flavors_ptn" || flavor_trial=
fi
- flavor=`database_build_make "$origin" -V FLAVOR 2> /dev/null || :`
+ origin_trial=`pkgsys_compose_flavored_origin "$origin_unflavored" "$flavor_trial"`
+ flavor=`database_build_make "$origin_trial" -V FLAVOR 2> /dev/null || :`
pkgsys_compose_flavored_origin "$origin_unflavored" "$flavor"
}
database_build_escape_inspect_conflict ()
{
local origin dbpath
+ origin=$1
dbpath=${DBDIR}/requires/$origin
if [ -e "$dbpath/CONFLICT.conf" ]
then
message_echo "${DEPTH_INDEX} ===> Escaping inspection conflict..."
- pkgsys_eval_ports_glob `cat "$dbpath/CONFLICT.conf"` | while read origin_conflict
- do
- pkg_conflict=`pkgsys_get_installed_pkg_from_origin "$origin_conflict"`
- [ -n "$pkg_conflict" ] || continue
- message_echo "${DEPTH_INDEX} ===> Escaping $pkg_conflict..."
- pkgarc=`pkgsys_create_backup_pkg "$pkg_conflict" "${DBDIR}/backup_packages" 2> /dev/null` || \
- message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to back up)"
- pkg_delete_f "$pkg_conflict" > /dev/null 2>&1 || \
- message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to delete)"
- [ -n "$pkgarc" ] && printf '%s\t%s\n' "$pkg_conflict" "$pkgarc" >> $dbpath/CONFLICT_pkgarc.lst
- done
+ pkgsys_eval_ports_glob `cat "$dbpath/CONFLICT.conf"` | database_build_escape "$dbpath/CONFLICT_pkgarc.lst"
fi
}
+# ============= Escape of conflicts =============
+# A list of conflict package origins are given by stdin.
+database_build_escape ()
+{
+ local backup_list origin_conflict pkg_conflict pkgarc
+ backup_list=$1
+ while read origin_conflict
+ do
+ pkg_conflict=`pkgsys_get_installed_pkg_from_origin "$origin_conflict"`
+ [ -n "$pkg_conflict" ] || continue
+ message_echo "${DEPTH_INDEX} ===> Escaping $pkg_conflict..."
+ pkgarc=`pkgsys_create_backup_pkg "$pkg_conflict" "${DBDIR}/backup_packages" 2> /dev/null` || \
+ message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to back up)"
+ pkg_delete_f "$pkg_conflict" > /dev/null 2>&1 || \
+ message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to delete)"
+ [ -n "$pkgarc" ] && printf '%s\t%s\n' "$pkg_conflict" "$pkgarc" >> $backup_list
+ done
+}
+
# ============= Restoration of escaped inspection conflict =============
database_build_restore_inspect_conflict ()
{
local origin dbpath
+ origin=$1
dbpath=${DBDIR}/requires/$origin
if [ -e "$dbpath/CONFLICT.conf" ]
then
message_echo "${DEPTH_INDEX} ===> Restoring inspection conflict..."
- cat "$dbpath/CONFLICT_pkgarc.lst" 2> /dev/null | while read pkg_conflict pkgarc
- do
- pkg_info_e "$pkg_conflict" && continue
- message_echo "${DEPTH_INDEX} ===> Restoring $pkg_conflict..."
- pkg_add_f "$pkgarc" > /dev/null 2>&1 || \
- message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to restore $pkg_conflict)"
- done
+ cat "$dbpath/CONFLICT_pkgarc.lst" 2> /dev/null | database_build_restore
rm -f "$dbpath/CONFLICT_pkgarc.lst"
fi
}
+# ============= Restoration of escaped conflicts =============
+# The backup list is given by stdin.
+database_build_restore ()
+{
+ local pkg_conflict pkgarc
+ while read pkg_conflict pkgarc
+ do
+ pkg_info_e "$pkg_conflict" && continue
+ message_echo "${DEPTH_INDEX} ===> Restoring $pkg_conflict..."
+ pkg_add_f "$pkgarc" > /dev/null 2>&1 || \
+ message_echo "${DEPTH_INDEX} ===> (WARNING: Failed to restore $pkg_conflict)"
+ done
+}
+
# ============= Recursively inspect dependencies of a port and build a node database of the information =============
database_build_inspect_dependencies ()
{
- local origin_orig origin_dependent origin_orig_regexp origin_replace origin_trial origin tag stage level dbpath dbpath_prev origin_id tmp_config origin_dependency DEPTH_INDEX_orig nlines iline dist_subdir_rpl inspected_level inspected_levels_compatible origin_tmp inspected_level_tmp conf_updated tmp_portsdb_work tmp_portopt same_as_prevset dbfile installed_version frompath variable pkg_new
+ local origin_orig origin_dependent origin_orig_regexp origin_replace origin tag stage level dbpath dbpath_prev origin_id tmp_config origin_dependency DEPTH_INDEX_orig nlines iline dist_subdir_rpl inspected_level inspected_levels_compatible origin_tmp inspected_level_tmp conf_updated tmp_portsdb_work tmp_portopt same_as_prevset dbfile installed_version frompath variable pkg_new
origin_orig=$1
origin_dependent=$2
[ -z "$origin_orig" ] && return
message_echo "${DEPTH_INDEX} $origin_orig"
database_build_convert_and_register_origin_if_obsolete__reset_origins_old
origin_id=`echo "$origin_orig" | tr / :`
- database_build_setup_initial_node "$origin_orig"
# Replacement specified by the configuration file, knobs and port options
- tmp_config=${TMPDIR}/database_build_inspect_dependencies:confi
- database_build_make "$origin_trial" showconfig > $tmp_config.before 2> /dev/null || :
- database_build_setup_replace_node "$origin_orig"
- database_build_make "$origin_trial" showconfig > $tmp_config.after 2> /dev/null || :
+ tmp_config=${TMPDIR}/database_build_inspect_dependencies:config
+ database_build_setup_replace_node "$origin_orig" "$tmp_config.before" "$tmp_config.after"
if [ -e "${DBDIR}/replace/$origin_orig/origin" ]
then
origin=`cat "${DBDIR}/replace/$origin_orig/origin"`
if ! grep -qFx "$origin" "${DBDIR}/done_required_ports_to_inspect" 2> /dev/null
then
fileedit_rm_a_line "$origin" "${DBDIR}/obsolete_ports"
+ fileedit_rm_a_line "$origin" "${DBDIR}/moved_ports"
dbpath=${DBDIR}/requires/$origin
dbpath_prev=${DBDIR}/prevset/requires/$origin
if [ ! -e "$dbpath/complete_as_node" ] || \
message_echo "WARNING: The following loop was found for requirements.${tag}${suffix}:" >&2
fi
message_echo " $origin" >&2
- sed -n $(($loophead+1)),\$p "$tmppath.parents" > $tmppath.ports_in_loop.tmp
- sed 's/^/ -->/' "$tmppath.ports_in_loop.tmp" | message_cat >&2
+ ports_in_loop=`sed -n $(($loophead+1)),\$p "$tmppath.parents"`
+ echo "$ports_in_loop" | sed 's/^/ -->/' | message_cat >&2
message_echo " -->$origin" >&2
if [ "x$opt_disallow_force_continuation_for_looped_dependency" = xyes ]
then
else
message_echo 'Exploring a node port to terminate the loop by evaluating only build-and-run-time dependencies as essential ones.' >&2
echo "$origin" > $tmppath.ports_in_loop
- cat "$tmppath.ports_in_loop.tmp" >> $tmppath.ports_in_loop
+ echo "$ports_in_loop" >> $tmppath.ports_in_loop
echo "$origin" >> $tmppath.ports_in_loop
index_loop=1
loop_len=`wc -l < $tmppath.ports_in_loop`
mkdir -p "$tmpdstpath"
database_build_filter_ignored_requirements "$origin" < $srcfile | while read origin_requirement
do
- database_build_get_complete_recursive_dependency "$tag" "$origin_requirement" "$suffix" \
- > $tmppath.recursive_dependency
+ # The least requirements of build are the direct build-time requirements and the full run-time requirements of the direct build-time requirements.
+ tag_dep=$tag
+ [ "x$tag" = xbuild ] && tag_dep=run
+ recursive_dependency=`database_build_get_complete_recursive_dependency "$tag_dep" "$origin_requirement" "$suffix"`
[ -e "$dbpath/ignored_requirements.filter" ] && \
echo "$origin_requirement" | grep -Fxq -f "$dbpath/ignored_requirements.filter" 2> /dev/null && \
continue
echo "$origin_requirement"
- cat "$tmppath.recursive_dependency"
+ echo "$recursive_dependency"
done > $dstfile_tmp
sed -n ${num_parents}p "$tmppath.parents" > $tmppath.parents.tmp
mv "$tmppath.parents.tmp" "$tmppath.parents"
if [ ! -e "$dstfile" ]
then
- sort -u "$dstfile_tmp" > $dstfile
+ sort -u "$dstfile_tmp" | grep -v '^$' > $dstfile || :
rm "$dstfile_tmp"
fi
fi
fi
}
+# ============= Recursively complete necessary upgrades for build =============
+database_build_complete_necessary_upgrades_for_build ()
+{
+ local origin level dbpath origin_requirement dbpath_requirement
+ origin=$1
+ level=$2
+ dbpath=${DBDIR}/requires/$origin
+ [ -e "$dbpath/requirements.build.${level}" ] || return 0
+ while read origin_requirement
+ do
+ dbpath_requirement=${DBDIR}/requires/$origin_requirement
+ [ -e "$dbpath_requirement/necessary_upgrade.build.${level}" ] || continue
+ [ `cat "${DBDIR}/moved_from/$origin_requirement/current_version" 2> /dev/null | wc -l` -eq 0 ] || continue
+ touch "$dbpath_requirement/necessary_upgrade.run.${level}"
+ database_build_complete_necessary_upgrades_for_build "$origin_requirement" "$level"
+ done < $dbpath/requirements.build.${level}
+ :
+}
+
# ============= Build target attribute files recursively =============
database_build_target_attributes ()
{
fileedit_rm_a_line "$origin" "${DBDIR}/ports.inspected.${level}.list"
done
fileedit_rm_a_line "$origin" "${DBDIR}/obsolete_ports"
+ fileedit_rm_a_line "$origin" "${DBDIR}/moved_ports"
fileedit_rm_a_line "$origin" "${DBDIR}/ports.inspected.list"
cat "${DBDIR}/replace/$origin/origin" 2> /dev/null || :
}
database_build_clear_db_dirs "$origin"
}
+# ============= Post-processes after finishing to inspect initial dependencies =============
+database_build_post_inspect_initial_dependencies ()
+{
+ find "${DBDIR}/initial" -depth 2 -type d \
+ | sed -E 's|.*/([^/]+/[^/]+)$|\1|' > ${DBDIR}/inspected_ports.initial
+}
+
# ============= Post-processes after finishing to inspect dependencies =============
database_build_post_inspect_dependencies ()
{
touch "${DBDIR}/obsolete_ports" "${DBDIR}/inspected_ports.update"
find "${DBDIR}/requires" -depth 2 -type d \
| sed -E 's|.*/([^/]+/[^/]+)$|\1|' > ${DBDIR}/inspected_ports
- find "${DBDIR}/initial" -depth 2 -type d \
- | sed -E 's|.*/([^/]+/[^/]+)$|\1|' > ${DBDIR}/inspected_ports.initial
sort -u "${DBDIR}/inspected_ports" "${DBDIR}/inspected_ports.initial" > ${DBDIR}/inspected_ports.all
{
cat "${DBDIR}/conf/HOLD:PORTS.parsed" || :