forked from artix/artools
		
	Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b734357ea9 | |||
| 74d44873e7 | |||
| 91e038c3f5 | |||
| 8548a584f3 | |||
| 38fb213e13 | 
@@ -18,19 +18,42 @@ m4_include(lib/base/message.sh)
 | 
			
		||||
m4_include(lib/pkg/repo.sh)
 | 
			
		||||
m4_include(lib/pkg/table.sh)
 | 
			
		||||
 | 
			
		||||
#{{{ db libs
 | 
			
		||||
 | 
			
		||||
extract_db() {
 | 
			
		||||
    local u="$1" cdir="$2"
 | 
			
		||||
    rm -rf "$cdir"
 | 
			
		||||
    mkdir -p "$cdir"
 | 
			
		||||
    msg2 "%s" "${cdir##*/}"
 | 
			
		||||
    curl -L -s "$u" | bsdtar -xf - -C "$cdir"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
update_db_cache(){
 | 
			
		||||
    msg "Updating database cache ..."
 | 
			
		||||
    local cachedir url
 | 
			
		||||
    for repo in "${searchrepos[@]}"; do
 | 
			
		||||
        cachedir=${db_cache_dir}/linksdb/$repo
 | 
			
		||||
        url=${REPOS_MIRROR}/$repo/os/${CARCH}/$repo.${linksdb_ext}
 | 
			
		||||
        extract_db "$url" "$cachedir"
 | 
			
		||||
    done
 | 
			
		||||
    msg "Done"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#}}}
 | 
			
		||||
 | 
			
		||||
#{{{ sogrep
 | 
			
		||||
 | 
			
		||||
query_db() {
 | 
			
		||||
    for repo in "${searchrepos[@]}"; do
 | 
			
		||||
        local db
 | 
			
		||||
        db=${db_cache_dir}/${linksdb_ext}/${CARCH}/${repo}/
 | 
			
		||||
        db=${db_cache_dir}/linksdb/$repo/
 | 
			
		||||
        if [[ -d ${db} ]]; then
 | 
			
		||||
            while read -rd '' pkg; do
 | 
			
		||||
                read -r match
 | 
			
		||||
                pkg=${pkg#${db}}
 | 
			
		||||
                pkg="${pkg%/*}"
 | 
			
		||||
                msg_row "${tableQ}" "${repo}" "${pkg}" "${match}"
 | 
			
		||||
            done < <(grep -rZ "${library}" "${db}") | sort -u
 | 
			
		||||
                msg_row "${tableQ}" "$repo" "$pkg" "${match}"
 | 
			
		||||
            done < <(grep -rZ "$library" "$db") | sort -u
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
}
 | 
			
		||||
@@ -41,7 +64,7 @@ query_db() {
 | 
			
		||||
 | 
			
		||||
is_db_entry() {
 | 
			
		||||
    local pkgname="$1" repo="${REPOS[$2]}" entry
 | 
			
		||||
    entry=${db_cache_dir}/${linksdb_ext}/${CARCH}/$repo/$pkgname
 | 
			
		||||
    entry=${db_cache_dir}/linksdb/$repo/$pkgname
 | 
			
		||||
 | 
			
		||||
    if [[ -d "$entry" ]];then
 | 
			
		||||
        return 0
 | 
			
		||||
@@ -50,20 +73,14 @@ is_db_entry() {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
check_db(){
 | 
			
		||||
    local pkgpath="${1}" oldpath="${1%/*}"/repos
 | 
			
		||||
    local pkgpath="${1}"
 | 
			
		||||
 | 
			
		||||
    for repo in "${!REPOS[@]}"; do
 | 
			
		||||
 | 
			
		||||
        local pkgbuild artixver
 | 
			
		||||
        if [[ -f $pkgpath/$repo/PKGBUILD ]]; then
 | 
			
		||||
            pkgbuild=$pkgpath/$repo/PKGBUILD
 | 
			
		||||
        elif [[ -f $oldpath/$repo-$CARCH/PKGBUILD ]]; then
 | 
			
		||||
            pkgbuild=$oldpath/$repo-$CARCH/PKGBUILD
 | 
			
		||||
        elif [[ -f $oldpath/$repo-any/PKGBUILD ]]; then
 | 
			
		||||
            pkgbuild=$oldpath/$repo-any/PKGBUILD
 | 
			
		||||
        fi
 | 
			
		||||
 | 
			
		||||
        if [[ -f "$pkgbuild" ]]; then
 | 
			
		||||
            # shellcheck disable=1090
 | 
			
		||||
            . "$pkgbuild" 2>/dev/null
 | 
			
		||||
            artixver=$(get_full_version)
 | 
			
		||||
@@ -81,6 +98,54 @@ check_db(){
 | 
			
		||||
 | 
			
		||||
#}}}
 | 
			
		||||
 | 
			
		||||
# {{{ check obsolete
 | 
			
		||||
 | 
			
		||||
show_obsolete_table() {
 | 
			
		||||
    local arch_mirror='https://mirror.f4st.host/archlinux'
 | 
			
		||||
 | 
			
		||||
    local arch_repo artix_repo artix_db arch_db url
 | 
			
		||||
    arch_repo="${searchrepos[@]}"
 | 
			
		||||
    artix_repo="${REPOS[$arch_repo]}"
 | 
			
		||||
 | 
			
		||||
    artix_db="${db_cache_dir}/artixdb/${artix_repo}"
 | 
			
		||||
    arch_db="${db_cache_dir}/archdb/${arch_repo}"
 | 
			
		||||
 | 
			
		||||
    msg "Updating database cache ..."
 | 
			
		||||
    url=${REPOS_MIRROR}/${artix_repo}/os/$CARCH/${artix_repo}.${db_ext}
 | 
			
		||||
    extract_db "$url" "${artix_db}"
 | 
			
		||||
 | 
			
		||||
    url=${arch_mirror}/${arch_repo}/os/$CARCH/${arch_repo}.${db_ext}
 | 
			
		||||
    extract_db "$url" "${arch_db}"
 | 
			
		||||
    msg "Done"
 | 
			
		||||
 | 
			
		||||
    msg_table_header "${tableQ}" "Repo" "Package" "Obsolete"
 | 
			
		||||
    for p in "${artix_db}"/*; do
 | 
			
		||||
        local pkg rel
 | 
			
		||||
        pkg=${p##*/}
 | 
			
		||||
        rel=${pkg##*-}
 | 
			
		||||
        rel=${rel%.*}
 | 
			
		||||
        pkg=${pkg%-*}
 | 
			
		||||
        local p="$pkg-$rel"
 | 
			
		||||
 | 
			
		||||
        if [[ "$p" != *openrc* ]] && [[ "$p" != *runit* ]] \
 | 
			
		||||
        && [[ "$p" != *s6* ]] && [[ "$p" != *suite66* ]] \
 | 
			
		||||
        && [[ "$p" != *eudev* ]] && [[ "$p" != *elogind* ]] \
 | 
			
		||||
        && [[ "$p" != *sysusers* ]] && [[ "$p" != *tmpfiles* ]] \
 | 
			
		||||
        && [[ "$p" != *execline* ]] && [[ "$p" != *skalibs* ]] \
 | 
			
		||||
        && [[ "$p" != *netifrc* ]] && [[ "$p" != *bootlogd* ]] \
 | 
			
		||||
        && [[ "$p" != *pam_rundir* ]] && [[ "$p" != *artools* ]] \
 | 
			
		||||
        && [[ "$p" != *archlinux* ]] && [[ "$p" != *iso-profiles* ]] \
 | 
			
		||||
        && [[ "$p" != *calamares* ]] && [[ "$p" != *iso-initcpio* ]] \
 | 
			
		||||
        && [[ "$p" != *dinit* ]] && [[ "$p" != *artix* ]]; then
 | 
			
		||||
            if [[ ! -d "${arch_db}/$p" ]]; then
 | 
			
		||||
                msg_row "${tableQ}" "${artix_repo}" "$p" "true"
 | 
			
		||||
            fi
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#}}}
 | 
			
		||||
 | 
			
		||||
show_lib_table() {
 | 
			
		||||
    msg_table_header "${tableQ}" "Repo" "Package" "Library"
 | 
			
		||||
    query_db
 | 
			
		||||
@@ -91,23 +156,10 @@ show_db_table(){
 | 
			
		||||
    tree_loop check_db
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
update_db_cache(){
 | 
			
		||||
    msg "Updating database cache ..."
 | 
			
		||||
    local cachedir url
 | 
			
		||||
    for repo in "${searchrepos[@]}"; do
 | 
			
		||||
        cachedir=${db_cache_dir}/${linksdb_ext}/${CARCH}/${repo}
 | 
			
		||||
        rm -rf "$cachedir"
 | 
			
		||||
        mkdir -p "$cachedir"
 | 
			
		||||
        msg2 "%s" "$repo"
 | 
			
		||||
        url=${REPOS_MIRROR}/${repo}/os/${CARCH}/${repo}.${linksdb_ext}
 | 
			
		||||
        curl -L -s "$url" | bsdtar -xf - -C "$cachedir"
 | 
			
		||||
    done
 | 
			
		||||
    msg "Done"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
db_cache_dir="${XDG_CACHE_HOME:-$USER_HOME/.cache}/artools"
 | 
			
		||||
 | 
			
		||||
linksdb_ext="links.tar.${DBEXT}"
 | 
			
		||||
db_ext="db.tar.${DBEXT}"
 | 
			
		||||
 | 
			
		||||
load_makepkg_config
 | 
			
		||||
 | 
			
		||||
@@ -115,9 +167,10 @@ sync=false
 | 
			
		||||
check=false
 | 
			
		||||
query=false
 | 
			
		||||
all_db=false
 | 
			
		||||
obsolete=false
 | 
			
		||||
 | 
			
		||||
readonly tableU="%-20s %-35s %-30s %-10s"
 | 
			
		||||
readonly tableQ="%-20s %-45s %s"
 | 
			
		||||
readonly tableQ="%-20s %-55s %s"
 | 
			
		||||
 | 
			
		||||
load_valid_names
 | 
			
		||||
 | 
			
		||||
@@ -162,6 +215,7 @@ usage() {
 | 
			
		||||
    echo "    -s            Sync repo databases"
 | 
			
		||||
    echo '    -c            Check repos'
 | 
			
		||||
    echo '    -a            Show repo db (-c)'
 | 
			
		||||
    echo '    -o            Check for obsolete packages'
 | 
			
		||||
    echo "    -q            Query repo databases for so libs"
 | 
			
		||||
    echo '    -h            This help'
 | 
			
		||||
    echo ''
 | 
			
		||||
@@ -169,7 +223,7 @@ usage() {
 | 
			
		||||
    exit "$1"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
opts='r:qcsah'
 | 
			
		||||
opts='r:qcsaoh'
 | 
			
		||||
 | 
			
		||||
while getopts "${opts}" arg; do
 | 
			
		||||
    case "${arg}" in
 | 
			
		||||
@@ -178,6 +232,7 @@ while getopts "${opts}" arg; do
 | 
			
		||||
        c) check=true ;;
 | 
			
		||||
        a) all_db=true ;;
 | 
			
		||||
        q) query=true ;;
 | 
			
		||||
        o) obsolete=true ;;
 | 
			
		||||
        h|?) usage 0 ;;
 | 
			
		||||
        *) echo "invalid argument '${arg}'"; usage 1 ;;
 | 
			
		||||
    esac
 | 
			
		||||
@@ -192,3 +247,5 @@ ${sync} && update_db_cache
 | 
			
		||||
${check} && show_db_table
 | 
			
		||||
 | 
			
		||||
${query} && show_lib_table
 | 
			
		||||
 | 
			
		||||
${obsolete} && show_obsolete_table
 | 
			
		||||
 
 | 
			
		||||
@@ -46,33 +46,6 @@ subrepo_pull(){
 | 
			
		||||
    git subrepo pull "$pkg"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
prepare_commit(){
 | 
			
		||||
    # create new layout, copy & remove repos
 | 
			
		||||
    if [[ -d repos ]]; then
 | 
			
		||||
        msg2 "Switching to new layout ..."
 | 
			
		||||
        [[ ! -d "$CARCH" ]] && mkdir "$CARCH"
 | 
			
		||||
 | 
			
		||||
        for r in repos/*; do
 | 
			
		||||
            local name noarch
 | 
			
		||||
            name=${r#*/}
 | 
			
		||||
            noarch=${name%-*}
 | 
			
		||||
            mkdir "$CARCH/${noarch}"
 | 
			
		||||
            cp repos/"${name}"/* "$CARCH/${noarch}/"
 | 
			
		||||
            git add "$CARCH/${noarch}"
 | 
			
		||||
        done
 | 
			
		||||
 | 
			
		||||
        git rm -r repos
 | 
			
		||||
        git commit -m "switch to new repo layout"
 | 
			
		||||
        msg2 "Done switch"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    if [[ $action == 'add' ]] || [[ $action == 'move' ]] ;then
 | 
			
		||||
        [[ -d "$CARCH/${repo_dest}" ]] && git rm -r "$CARCH/${repo_dest}"
 | 
			
		||||
        [[ ! -d "$CARCH" ]] && mkdir "$CARCH"
 | 
			
		||||
        [[ ! -d "$CARCH/${repo_dest}" ]] && mkdir "$CARCH/${repo_dest}"
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
check_rebuild(){
 | 
			
		||||
    if [[ -d "$CARCH"/"${valid_names[10]}" ]] \
 | 
			
		||||
    && [[ "${repo_dest}" == "${valid_names[7]}" ]]; then
 | 
			
		||||
@@ -104,11 +77,6 @@ check_team(){
 | 
			
		||||
path_config() {
 | 
			
		||||
    [[ "${repo_src}" != 'trunk' ]] && pkgbuild="$CARCH/${repo_src}"/PKGBUILD
 | 
			
		||||
 | 
			
		||||
    if [[ ! -f "$pkgbuild" ]]; then
 | 
			
		||||
        pkgbuild=repos/"${repo_src}-${CARCH}"/PKGBUILD
 | 
			
		||||
        [[ -f repos/"${repo_src}"-any/PKGBUILD ]] && pkgbuild=repos/"${repo_src}"-any/PKGBUILD
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    # shellcheck disable=1090
 | 
			
		||||
    . "$pkgbuild"
 | 
			
		||||
}
 | 
			
		||||
@@ -130,7 +98,6 @@ commit_pkg() {
 | 
			
		||||
        if [[ "${repo_src}" == 'trunk' ]];then
 | 
			
		||||
            git rm -r trunk
 | 
			
		||||
        else
 | 
			
		||||
            prepare_commit
 | 
			
		||||
            git rm -r "$CARCH/${repo_src}"
 | 
			
		||||
        fi
 | 
			
		||||
    else
 | 
			
		||||
@@ -144,11 +111,15 @@ commit_pkg() {
 | 
			
		||||
 | 
			
		||||
repo_commit_pkg() {
 | 
			
		||||
    local commit_msg
 | 
			
		||||
 | 
			
		||||
    [[ -d "$CARCH/${repo_dest}" ]] && git rm -r "$CARCH/${repo_dest}"
 | 
			
		||||
    [[ ! -d "$CARCH" ]] && mkdir "$CARCH"
 | 
			
		||||
    [[ ! -d "$CARCH/${repo_dest}" ]] && mkdir "$CARCH/${repo_dest}"
 | 
			
		||||
 | 
			
		||||
    if [[ "${repo_src}" == 'trunk' ]]; then
 | 
			
		||||
        action='add'
 | 
			
		||||
        commit_msg=$(get_repo_commit_msg)
 | 
			
		||||
        msg "Action: %s" "$commit_msg"
 | 
			
		||||
        prepare_commit
 | 
			
		||||
        check_rebuild
 | 
			
		||||
        cp trunk/* "$CARCH/${repo_dest}"/
 | 
			
		||||
    else
 | 
			
		||||
@@ -156,7 +127,6 @@ repo_commit_pkg() {
 | 
			
		||||
        [[ ! -f $pkgbuild ]] && die "%s does not exist!" "$pkgbuild"
 | 
			
		||||
        commit_msg=$(get_repo_commit_msg)
 | 
			
		||||
        msg "Action: %s" "$commit_msg"
 | 
			
		||||
        prepare_commit
 | 
			
		||||
        cp "$CARCH/${repo_src}"/* "$CARCH/${repo_dest}"/
 | 
			
		||||
        git rm -r "$CARCH/${repo_src}"
 | 
			
		||||
    fi
 | 
			
		||||
 
 | 
			
		||||
@@ -41,7 +41,7 @@ find_pkg(){
 | 
			
		||||
tree_loop(){
 | 
			
		||||
    local func="$1" pkgs
 | 
			
		||||
    for tree in "${ARTIX_TREE[@]}"; do
 | 
			
		||||
        pkgs=$(find "${TREE_DIR_ARTIX}/$tree" -name repos -o -name "$CARCH" | sort)
 | 
			
		||||
        pkgs=$(find "${TREE_DIR_ARTIX}/$tree" -name "$CARCH" | sort)
 | 
			
		||||
        for _package in ${pkgs}; do
 | 
			
		||||
            "$func" "$_package"
 | 
			
		||||
        done
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user