当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 6 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : pacfile脚本分析
帖子发表于 : 2009-07-08 19:56 

注册: 2008-10-04 20:34
帖子: 62
地址: young001.blogbus.com
送出感谢: 0 次
接收感谢: 0 次
版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
http://young001.blogbus.com/logs/42067599.html

#!/bin/bash

#这是个非常典型的shell编程实现,调用一些构造函数实现自己想要的功能。而且这个程序的实现也没有使用高级功能,非常适合初学者来学##习,中间如果有理解不当,万望指正啊。

#-----------------------------------------------------------
# A utility for discovering which ArchLinux package contains
# a given file. Downloads filelists for all active repos in
# pacman.conf; uses mirrors in order according to pacman's
# mirrorlist file.
#一个查询archlinux包中含有什么文件的的工具。通过下载软件库中filelists实现
#-----------------------------------------------------------

db=/var/lib/pacman/filelists
#定义数据存放地址
pacmanconf=/etc/pacman.conf
#pacman设置文件地址
mirrorlist=/etc/pacman.d/mirrorlist
#pacman镜像地址

#-----------------------------------------------------------
# Print active repos in $pacmanconf.
#-----------------------------------------------------------
function list_repos() {
sed -n '/REPOSITORIES/,$ s/^\[\(.*\)\]/\1/p' $pacmanconf
}
#打印活动软件库。 s/^\[\(.*\)\]/\1/p,我来解释一下。s///p这是替换之后打印替换行
#^\[表示查询[开头的句子,\ 就是一个转义作用。[\(.*\)这是后面\1联用,\1就是用\(.*\)中内容替换。

#-----------------------------------------------------------
# Print active mirrors in $mirrorlist.
#-----------------------------------------------------------
function list_mirrors() {
sed -n 's/^Server = \(.*\)$/\1/p' $mirrorlist
}
#这就是在mirrorlist中查找Server开头的句子打印
#-----------------------------------------------------------
# Download the filelist for repo $1. Assumes $mirrors
# is an array of urls to check for $file.
#在repo文件中mirror下载filelists,这里假设的是你的镜像有多个。
#-----------------------------------------------------------
function download() {
repo=$1
file="${repo}.files.tar.gz"
#一些定义,$1就是上面定义的function list_repos()返回值

i=0
while [[ ! -e "${db}/${file}" ]]; do
#判断是否存在file文件
if (( $i >= ${#mirrors[@]} )); then
return 1
#判断完返回值1
fi

url=$(echo "${mirrors[$i]}" | sed "s/\$repo/$repo/g")
#这是下载file文件的地址
wget --connect-timeout=15 -P "$db" "${url}/${file}"
let i+=1
#使用wget下载 -P就是定义下载地址
done
}
#这就是定义一个下载file文件的函数。

#-----------------------------------------------------------
# Decompress $1 into dir $2.
#-----------------------------------------------------------
#一下就是解压file文件的过程
function decompress() {
file=$1
repo=$2

mkdir "${db}/${repo}"
tar -xzf "${db}/${file}" -C "${db}/${repo}"
#加压文件到"${db}/${repo}"中 -C就是指定解压目录
rm -f "${db}/${file}"
}

#-----------------------------------------------------------
# Download the filelist for each active repo in
# pacman.conf. Tries mirrors in order until successful.
#-----------------------------------------------------------
function sync() {
mirrors=($(list_mirrors))
for repo in $(list_repos); do
echo "Fetching filelist for $repo"
download "$repo"
if [[ $? == 0 ]]; then
decompress "$file" "$repo"
else
echo
echo "Error: unable to retrieve $file from any mirror."
echo
fi
done
}
#这段比较容易,就是调用了上面的download函数下载filelists并且使用decompress函数来解压。如果失败打印Error: unable to retrieve $#file from any mirror."


#-----------------------------------------------------------
# Print usage message.
#-----------------------------------------------------------
function usage() {
echo "usage: $(basename $0) [options] [pattern]"
echo echo "Search package filelists for [pattern]."
echo "options:"
echo " $(basename $0) [-h --help] Print this help message."
echo " $(basename $0) [-S --sync] Syncronize package filelists."
}
#这个就是定义使用了,你直接输入pacfile就可以看见这个函数的效果了。

#-----------------------------------------------------------
# Start of `main'.
#-----------------------------------------------------------
#函数全部搞定,接下来就是main函数了
case "$1" in
-S|--sync)
if [[ $EUID != 0 ]]; then
#如果你同步,判断是否为root,如果不是输出以下文字,提醒你要使用root来更新。
echo "error: you cannot perform this operation unless you are root."
exit 1;
fi
#如果判断的确是root了,接下来就同步一下。

echo "Syncronizing ${db}..."; echo
rm -rf "$db" && mkdir -p "$db"
sync
;;

-h|--help)
usage
#-h,调用usage函数
;;
*)
if [[ $# < 1 ]]; then
echo "not enough parameters"; echo
usage
exit 1
fi
#如果没有跟查询对象,即<1,输出没有有效对象

if [[ ! -d "$db" ]]; then
echo "File database \"$db\" does not exist!"
echo "Have you synchronized the database?"
echo
exit 1
fi
#如果没有db存在,提醒是否同步过?
grep -rE "$@" "$db" | sed "s|$db/\(.*\)/files:|\1 |g"
#这句就是pacfile工作的原理,调用grep来查询,所以还是支持*等grep方式查询的。
;;
esac


_________________
http://young001.blogbus.com
努力做自己的博客,欢迎来踩


页首
 用户资料  
 
2 楼 
 文章标题 : Re: pacfile脚本分析
帖子发表于 : 2009-07-08 20:01 
头像

注册: 2007-11-19 21:51
帖子: 6956
地址: 成都
送出感谢: 0 次
接收感谢: 4
不错,我的arch未安装命令提示就是用这个东东产生命令列表的。


页首
 用户资料  
 
3 楼 
 文章标题 : Re: pacfile脚本分析
帖子发表于 : 2009-07-08 23:11 
头像

注册: 2007-09-29 3:09
帖子: 5773
送出感谢: 0 次
接收感谢: 3
不就是一grep有啥好分析...


_________________
HUNT Unfortunately No Talent...


页首
 用户资料  
 
4 楼 
 文章标题 : Re: pacfile脚本分析
帖子发表于 : 2009-07-10 9:35 
头像

注册: 2006-04-12 20:05
帖子: 8495
地址: 杭州
送出感谢: 0 次
接收感谢: 8
不用arch的,看这个很没意思....要不转到arch版去?


_________________
关注我的blog: ε==3


页首
 用户资料  
 
5 楼 
 文章标题 : Re: pacfile脚本分析
帖子发表于 : 2009-07-10 9:39 
头像

注册: 2005-08-14 21:55
帖子: 58428
地址: 长沙
送出感谢: 4
接收感谢: 272
这样的事情,不用perl作,哎。


_________________
● 鸣学


页首
 用户资料  
 
6 楼 
 文章标题 : Re: pacfile脚本分析
帖子发表于 : 2009-07-10 10:09 
头像

注册: 2007-11-19 21:51
帖子: 6956
地址: 成都
送出感谢: 0 次
接收感谢: 4
eexpress 写道:
这样的事情,不用perl作,哎。

这叛徒,以前爱bash爱得要死,现在又叛变到perl :em36


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 6 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 3 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译