diff options
-rwxr-xr-x | bin/db-update | 72 |
1 files changed, 36 insertions, 36 deletions
diff --git a/bin/db-update b/bin/db-update index 4808f2b..55c32db 100755 --- a/bin/db-update +++ b/bin/db-update @@ -12,11 +12,6 @@ # TODO: we should delete more packages than just the ones in repositories # where we move to (think of [extra] -> [community]) -# TODO: enable separate repositories for each architecture - -# TODO: operate on `binary_packages_in_repositories` instead of -# `binary_packages` - # shellcheck disable=SC2039,SC2119,SC2120 # shellcheck source=../lib/load-configuration @@ -255,22 +250,26 @@ for source_stability in \ printf ' FROM `replaced_bpir`' printf ' JOIN `binary_packages_in_repositories` ON `replaced_bpir`.`id`=`binary_packages_in_repositories`.`id`;\n' - printf 'SELECT "repositories",`repositories`.`name`' - printf ' FROM `repositories`' - printf ' JOIN `rps` ON `rps`.`id`=`repositories`.`id`;\n' + printf 'SELECT "repositories",`architectures`.`name`,`repositories`.`name`' + printf ' FROM `rps`' + printf ' JOIN `repositories` ON `rps`.`id`=`repositories`.`id`' + mysql_join_repositories_architectures + printf ';\n' printf 'SELECT "mv.id",`moveable_bpir`.`id`,`moveable_bpir`.`to_repository`' printf ' FROM `moveable_bpir`;\n' printf 'SELECT "mv",' mysql_package_name_query - printf ',`repositories`.`name`,`new_repo`.`name`' + printf ',`r_a`.`name`,`repositories`.`name`,`new_r_a`.`name`,`new_repo`.`name`' printf ' FROM `moveable_bpir`' printf ' JOIN `binary_packages_in_repositories` ON `moveable_bpir`.`id`=`binary_packages_in_repositories`.`id`' mysql_join_binary_packages_in_repositories_binary_packages mysql_join_binary_packages_in_repositories_repositories mysql_join_binary_packages_architectures + mysql_join_repositories_architectures '' 'r_a' printf ' JOIN `repositories` AS `new_repo` ON `new_repo`.`id`=`moveable_bpir`.`to_repository`' + mysql_join_repositories_architectures 'new_repo' 'new_r_a' printf ';\n' printf 'SELECT "rm.id",`replaced_bpir`.`id`' @@ -278,12 +277,13 @@ for source_stability in \ printf 'SELECT "rm",' mysql_package_name_query - printf ',`repositories`.`name`' + printf ',`r_a`.`name`,`repositories`.`name`' printf ' FROM `replaced_bpir`' printf ' JOIN `binary_packages_in_repositories` ON `replaced_bpir`.`id`=`binary_packages_in_repositories`.`id`' mysql_join_binary_packages_in_repositories_binary_packages mysql_join_binary_packages_in_repositories_repositories mysql_join_binary_packages_architectures + mysql_join_repositories_architectures '' 'r_a' printf ';\n' } | \ mysql_run_query | \ @@ -313,14 +313,14 @@ for source_stability in \ # receive the repository databases from the master mirror mkdir "${tmp_dir}/dbs" - while read -r repo; do - mkdir "${tmp_dir}/dbs/${repo}" + while read -r arch repo; do + mkdir -p "${tmp_dir}/dbs/${arch}/${repo}" # shellcheck disable=SC2086 ${master_mirror_rsync_command} \ - "${master_mirror_rsync_directory}/i686/${repo}/${repo}.db."* \ - "${master_mirror_rsync_directory}/i686/${repo}/${repo}.files."* \ - "${tmp_dir}/dbs/${repo}/" - tar -Oxzf "${tmp_dir}/dbs/${repo}/${repo}.db.tar.gz" --wildcards '*/desc' | \ + "${master_mirror_rsync_directory}/${arch}/${repo}/${repo}.db."* \ + "${master_mirror_rsync_directory}/${arch}/${repo}/${repo}.files."* \ + "${tmp_dir}/dbs/${arch}/${repo}/" + tar -Oxzf "${tmp_dir}/dbs/${arch}/${repo}/${repo}.db.tar.gz" --wildcards '*/desc' | \ sed -n ' /^%FILENAME%$/{ N @@ -341,42 +341,42 @@ for source_stability in \ # remove to-be-deleted packages # shellcheck disable=SC2094 - cut -d' ' -f2 < \ + cut -d' ' -f2,3 < \ "${tmp_dir}/rm" | \ sort -u | \ - while read -r repo; do - grep " $(str_to_regex "${repo}")\$" "${tmp_dir}/rm" | \ + while read -r arch repo; do + grep " $(str_to_regex "${arch} ${repo}")\$" "${tmp_dir}/rm" | \ sed ' - s/\(-[^-]\+\)\{3\} \S\+$// + s/\(-[^-]\+\)\{3\} \S\+ \S\+$// ' | \ - xargs -r repo-remove -q "${tmp_dir}/dbs/${repo}/${repo}.db.tar.gz" + xargs -r repo-remove -q "${tmp_dir}/dbs/${arch}/${repo}/${repo}.db.tar.gz" done # copy and delete moved packages # shellcheck disable=SC2094 - cut -d' ' -f2,3 < \ + cut -d' ' -f2,3,4,5 < \ "${tmp_dir}/mv" | \ sort -u | \ - while read -r from_repo to_repo; do - grep " $(str_to_regex "${from_repo}") $(str_to_regex "${to_repo}")\$" "${tmp_dir}/mv" | \ + while read -r from_arch from_repo to_arch to_repo; do + grep " $(str_to_regex "${from_arch} ${from_repo} ${to_arch} ${to_repo}")\$" "${tmp_dir}/mv" | \ sed ' - s/-[^-]\+ \S\+ \S\+$// + s/-[^-]\+\( \S\+\)\{4\}$// ' | \ xargs -r "${base_dir}/bin/repo-copy" \ - "${tmp_dir}/dbs/${from_repo}/${from_repo}.db.tar.gz" \ - "${tmp_dir}/dbs/${to_repo}/${to_repo}.db.tar.gz" - grep " $(str_to_regex "${from_repo}") $(str_to_regex "${to_repo}")\$" "${tmp_dir}/mv" | \ + "${tmp_dir}/dbs/${from_arch}/${from_repo}/${from_repo}.db.tar.gz" \ + "${tmp_dir}/dbs/${to_arch}/${to_repo}/${to_repo}.db.tar.gz" + grep " $(str_to_regex "${from_arch} ${from_repo} ${to_arch} ${to_repo}")\$" "${tmp_dir}/mv" | \ sed ' - s/\(-[^-]\+\)\{3\} \S\+ \S\+$// + s/\(-[^-]\+\)\{3\}\( \S\+\)\{4\}$// ' | \ xargs -r repo-remove -q \ - "${tmp_dir}/dbs/${from_repo}/${from_repo}.db.tar.gz" + "${tmp_dir}/dbs/${from_arch}/${from_repo}/${from_repo}.db.tar.gz" done # create real file names of packages, because # mysql_query_and_delete_unneeded_binary_packages does so, too sed -i ' - s,^\(\S\+\) \(\S\+\)$,i686/\2/\1, + s,^\(\S\+\) \(\S\+\) \(\S\+\)$,\2/\3/\1, ' "${tmp_dir}/rm" # shellcheck disable=SC2016 @@ -408,7 +408,7 @@ for source_stability in \ s/"$/.sig"/ ' "${tmp_dir}/rm" sed ' - s,^\(\S\+\) \(\S\+\) \(\S\+\)$,rename "i686/\2/\1" "i686/\3/\1"\nrename "i686/\2/\1.sig" "i686/\3/\1.sig", + s,^\(\S\+\) \(\S\+\) \(\S\+\) \(\S\+\) \(\S\+\)$,rename "\2/\3/\1" "\4/\5/\1"\nrename "\2/\3/\1.sig" "\4/\5/\1.sig", ' "${tmp_dir}/mv" echo 'quit' } | \ @@ -423,12 +423,12 @@ for source_stability in \ fi # and push our local *.db.tar.gz via rsync - while read -r repo; do + while read -r arch repo; do # shellcheck disable=SC2086 ${master_mirror_rsync_command} \ - "${tmp_dir}/dbs/${repo}/${repo}.db."* \ - "${tmp_dir}/dbs/${repo}/${repo}.files."* \ - "${master_mirror_rsync_directory}/i686/${repo}/" + "${tmp_dir}/dbs/${arch}/${repo}/${repo}.db."* \ + "${tmp_dir}/dbs/${arch}/${repo}/${repo}.files."* \ + "${master_mirror_rsync_directory}/${arch}/${repo}/" done < \ "${tmp_dir}/repositories" |