星期二, 十二月 19, 2006

可爱的yn妹妹

原来yn妹妹还是很pl的
呵呵
自己一直都没特别注意,就是觉得她是还过得去的那种,和她在一起也完全是因为她的善良,温柔,体贴
呵呵,昨天有人说mm长得pl,好开心啊,我也喜欢我的丫头ppll的
原来自己身边一直都藏着这么个美女都没法现啊

呵呵,还好被我给骗到了(用骗这个词ynmm可不要打我啊)
这几天越来越觉得mm温柔,pl,可爱依人
真是个合格的好lp
衷心祝福ynmm越来越pl
以后一定赚多多的money好给mm
梳妆,打扮
呵呵,其实自己还是很虚荣的啊,我也喜欢自己的mm漂漂亮,
自己也有光啊
就写这么多吧,在写mm揍我了
亲亲mm一个
好梦啊mm

Read More...

毕设

题目下来了,呵呵终于如愿以偿选到了自己喜欢的老师
很开心,昨天就想写了
可是每次来写的时候都有事
所以就只能这时候来写了




Read More...

星期五, 十二月 15, 2006

yn妹妹,辛苦了

这几天事比较多
我的脾气也不是很好
以后要更好的对你
宝贝辛苦了


Read More...

星期六, 十二月 09, 2006

我的桌面

desktop1


desktop2

Read More...

星期四, 十二月 07, 2006

An easier way to update your world

Without doubt, one of Gentoo's best features is its package management system, Portage. Portage makes it very easy to update your entire system with one simple command. Sadly, things don't always go as smooth as they should. Almost every Gentoo user has typed emerge -uD world and gone to bed with the hope of waking up in the morning to a completely up to date system. Unfortunately, it's more likely that you.ll wake up to a failed emerge on package 3 of 220. And so the troubleshoot and emerge --resume process begins.

Enter update-world to save the day. Update-world is a bash script that was recently created by count_zero and posted in the forums. The script controls the update process and forces portage to skip past failed builds and continue compiling packages until the update list is finished. Failed builds are added to a list for review once the update is finished.

Note: The script does depend on the 'equery' command, part of app-portage/gentoolkit.



Obviously before you can start using the script, you'll need to download it, put it somewhere in your path, and make it executable.

Code Listing 3.1: getting the script

# wget -O /usr/bin/update-world http://countzero.amidal.com/files/update-world
# chmod +x /usr/bin/update-world

Now we're ready to start using the script.

Code Listing 3.2: running update-world

# update-world --prepare 

This begins the update process by creating a list of packages to be emerged, as produced by emerge -uD --newuse world. (Alternatively, you can use update-world --empty to create a list of all packages on the system, akin to emerge -e world). This command creates a list called 'emergelist' in ~/.update-world/. Now, you can use your favorite editor to modify this list how you like--remove packages, change versions, etc. When you have the emergelist how you like it, you're ready to move onto the next step:

Code Listing 3.3: running update-world (cont)

# update-world --install 

This command actually starts the build process, just as if you had typed emerge -uD world. The difference is, if a package fails for some reason or another, that package is added to a list 'failedlist' in ~/.update-world/. Also, a link to the portage log file for that package (usually located in /var/log/portage) is created in ~/.update-world/[date]/log/. Once the process is done, you'll be presented with a list of failed packages to take care of all at once, saving much time. If you ever need to stop the process, just hit 'Control-C' to abort the process. The update can then be restarted at any time, just where it left off, by retyping update-world --install.


[code]
#!/bin/bash
# update-world 1.5
# count_zero 2006
# Licensed under the GPLv2
#
# update-world is a bash script that forces an emerge -uD world to continue, even
# in the face of (inevitable) compile failures. Failed builds are added to a list,
# and the script jumps to the next package in the queue.
#
# just run update-world --prepare (or --empty) followed by update-world --install.
#
# Release Notes:
# v1.5: now handles 'fetch restriction' properly
# v1.4: uses '--newuse' for emerges to respect new use flags
# v1.3: uses '--oneshot' for emerges so they don't get added to the world file.
# v1.2: Script now detects log directly instead of accepting only /var/log/portage
# v1.1: minor bugfix to allow package without version to be added to 'emergelist'
# v1.0: Release
#
#
# Set the program directory and important variables
homedir=~/.update-world
workdir="$homedir/`date +%F`"
logdir="$workdir/log"
mkdir -p $logdir
touch $homedir/failedlist
emergelist=$homedir/emergelist
emergetemp=$workdir/emergetemp
failedlist=$homedir/failedlist
portlogdir=`cat /etc/make.conf | grep PORT_LOGDIR | sed 's/PORT_LOGDIR=//' | sed 's/\"//g' | sed 's/\/$//'`
masked=$homedir/masked
# parameter for '--empty' to emerge -e world
if [[ $1 == '--empty' || $1 == '-e' ]]
then parameter='-pev'
else parameter='-puvD --newuse'
fi
#### update-world --prepare ####
# Prepare the list of packages to emerge into emerglist
if [[ $1 == "--prepare" || $1 == "-p" || $1 == '--empty' || $1 == '-e' ]]
then
if [[ -e $emergelist ]]
then echo -n "The file 'emergelist' already exists and will be overwritten.
Continue anyway? (y/n) "
read continue
if [[ $continue == 'y' || $continue == 'yes' || $continue == 'Y' || $continue == 'Yes' || $continue == 'YES' || $continue == '' ]]
then :
else echo exiting.
exit 0
fi
else :
fi
emerge $parameter world | tee $emergelist
# Make sure there are no errors in the emerge process
echo
if grep -q "blocks B " $emergelist
then echo "WARNING: You have a blocking package. Fix this before continuing."
rm -f $emergelist
exit 1
elif grep -q "masked" $emergelist
then echo "WARNING: You need to unmask some packages before continuing."
rm -f $emergelist
exit 1
elif grep -q "emerge: there are no ebuilds to satisfy" $emergelist
then echo "WARNING: One of the specified packages doesn't exist"
rm -f $emergelist
exit 1
elif grep -q 'Fetch Restriction' $emergelist
then fetchrestricted=`cat $emergelist | grep ^[[]ebuild[A-Za-z\ ]*F[A-Za-z\ ]*[]] | grep -o []][a-zA-Z0-9\/.\ -]*[[] | sed 's/\]\ //' | sed 's/\ \[//'`
echo "WARNING: The following packages have Fetch Restriction turned on:
$fetchrestricted

Please download the sources from the location specified in the ebuild to /usr/portage/distfiles/ and rerun this script."
exit 1
else :
fi
echo "
These are the packages that will be installed. If you want to alter this list,
just edit the file 'emergelist' in $homedir. When finished, run
'update-world --install'"
cat $emergelist | sed '/^[TC]/d' | sed 's/\[ebuild.*[ A-Z]\]\ //' | sed '/^[ ]/d' | sed '/^[ ]*$/d' | sed '/Portage\ overlays/d' | sed 's/\ .*$//' | sort -d | sed 's/.*/\=&/' > $emergetemp
mv $emergetemp $emergelist
rm -f $failedlist
exit 0
#### update-world --install ####
# Install the packages listed in emergelist
elif [[ $1 == "--install" || $1 == "-i" ]]
then
# Verify that the emergelist doesn't produce errors
cat $emergelist | xargs emerge -p > $emergetemp
if grep -q "blocks B " $emergetemp
then echo "WARNING: You have a blocking package. Fix this before continuing."
rm -f $emergetemp
exit 1
elif grep -q "masked" $emergelist
then echo "WARNING: You need to unmask some packages before continuing."
rm -f $emergetemp
exit 1
elif grep -q "emerge: there are no ebuilds to satisfy" $emergelist
then echo "WARNING: One of the specified packages doesn't exist"
rm -f $emergetemp
exit 1
elif [[ -z `cat $emergelist` ]]
then echo "WARNING: no 'emergelist' exists. Did you run 'update-world --prepare' first?"
rm -f $emergetemp
exit 1
else :
fi
# Until loop to make portage continue until finished
increment=0
until [[ $increment == 1 ]]
do
cat $emergelist | xargs emerge -1
# Detect which packages have been successfully emerged and remove from the queue
installed=`tac /var/log/emerge.log | sed '/Started\ emerge/,$d' | grep "completed emerge" | sed 's/^.*)\ //' | sed 's/\ to.*//'`
for each in $installed
do
eachsed=`echo $each | sed 's|\/|\\\/|'`
if [[ -z `cat $emergelist | grep $each` ]]
then eachsed=`echo $eachsed | sed 's/\-[0-9].*//'`
else :
fi
cat $emergelist | sed "/$eachsed/d" > $emergetemp
mv $emergetemp $emergelist
done
# See if all packages have been emerged
if [[ -z `cat $emergelist` ]]
then increment=1
else :
fi
if [[ $increment == 0 ]]
then
errorlog=`ls -t $portlogdir | sed '2,$d'`
if [[ -n `cat $portlogdir/$errorlog | grep 'signal 2'` ]]
then echo "
*** User hit 'Control-C' ... exiting.
"
exit 1
else :
fi
sleep 5
echo
echo "*** Hit Control-C to exit, or just wait to continue with emerge."
echo
sleep 10
echo "*** Continuing with emerge."
# Detect failed emerge and add to failedlist, remove failed package from emergelist
failedpkg=`tac /var/log/emerge.log | sed '1d' | sed '/terminating/,$d' | sed '/completed\ emerge/,$d' | grep ">>>" | sed 's/.*)\ //' | sed 's/\ to.*//'`
if [[ -n `tail -n 1 $failedlist | grep $failedpkg` ]]
then echo "The failed package $failedpkg could not be merged and must be successfully installed before continuing."
exit 1
else :
fi
echo $failedpkg >> $failedlist
failedpkgsed=`echo $failedpkg | sed 's|\/|\\\/|'`
cat $emergelist | sed "/$failedpkgsed/d" > $emergetemp
mv $emergetemp $emergelist
ln -s $portlogdir/$errorlog $logdir/${errorlog}_error-log
echo
echo
echo "*** $failedpkg compile failed, skipping."
# Is there a package in 'emergelist' that requires the failed pkg as a dep? If so, remove it too.
failedpkgdeps=`echo $failedpkg | sed 's/-[0-9].*//'`
deps=`equery depends $failedpkgdeps | sed '/^\[/d' | sed 's/-[0-9].*//'`
for each in `echo $deps`
do
if [[ -n `cat $emergelist | grep "$each"` ]]
then
if [[ -n `emerge -p $each | grep "$failedpkg"` ]]
then
each2=`cat $emergelist | grep $each | sed 's/\=//'`
echo "$each2 (depends on $failedpkg)" >> $failedlist
eachsed=`echo $each | sed 's|\/|\\\/|'`
cat $emergelist | sed "/$eachsed/d" > $emergetemp
mv $emergetemp $emergelist
echo "*** $each depends on $failedpkg, skipping."
else :
fi
else :
fi
done
echo "*** Continuing with emerge world"
else :
fi
done
# if improper argument is given to 'update-world' display the help text
else echo "update-world 1.0
count_zero 2006
licensed under the GPLv2

Description:
This is a bash script to automate the 'emerge -uD world' process.
Its purpose is to make updating the system as hands-free as possible.
It does this by automatically recovering from a failed emerge and moving
on to the next one, presenting the user with a list of failed packages
once the update has finished. No more 'babysitting' the update process!
Just start it, and deal with any failed packages at the end. Log files
from the failed emerges are saved in the log directory.

The default program directory is ~/.update-world

Usage:
update-world [--prepare | -p ]
Prepares a list of packages produced by 'emerge -puvD world'
and outputs them to the file 'emergelist' in the current directory.
Add, remove, or change the version of any of the packages listed
in this file with your favorite editor before continuing.
update-world [--empty | -e ]
Same as --prepare except it performs 'emerge -ev world' to recompile
all packages on a system.
update-world [--install | -i ]
Begins the emerge process based upon the 'emergelist' file created
from running 'update-world --prepare'. Once finished, failed builds
will be saved in the file 'failedlist' in the current directory."
exit 1
fi


echo "Congratulations! 'emerge world' complete."
echo
# All done! display the failed packages, if any
if [[ -z `cat $failedlist` ]]
then echo "All packages emerged successfully"
else echo "These packages couldn't be merged due to compile errors:"
echo
cat $failedlist
echo
echo "Look in $logdir/ for the portage log files of the failed builds.
Check bugs.gentoo.org or the Gentoo Forums for help."
fi
exit 0
[/code]

Read More...

星期二, 十二月 05, 2006

HOWTO Compile Kernel

安装内核源代码

代码: 安装内核源代码
$ USE=symlink emerge gentoo-sources

使用symlink的目的是建立符号连接/usr/src/linux,以指向安装好的内核源代码目录。

警告: 目前使用上面的命令装的是2.6内核,下面的命令也适用于2.6内核,但不一定适用于2.4内核。不过现在没有必要再用2.4内核。特别是在目前glibc 2.4已经稳定了的情况下,已经根本无法再用2.4内核。

配置

配置内核对于新手来说是一个噩梦。不过事实上,配置过程要远比一般人想象的容易。只是有些技巧了解的人不多。

配置命令介绍

make defconfig

非交互式命令,作用是生成一个缺省的配置文件。这个配置文件里各内核组件基本完整,只需修改硬件和文件系统即可。仅在第一次配置时使用。

make menuconfig

最通用的配置方式。它的运行几乎不限环境,远程登录也可以用它配置,所以我们重点介绍。

交互式命令。用法如下:

  • 方向键选择菜单项/按钮
  • 回车进入子菜单
  • 按高亮字母直接选择相应菜单项
  • Y键包含,N键排除,M键配置成模块
  • 退出,?键查看当前菜单项帮助信息,/键搜索
  • 图例:[*] 包含 [ ] 排除 模块 < > 可配置成模块

make oldconfig

交互式命令。利用已有的.config来生成新的.config。如果遇到新内核新增的选项,会挨个提示你是否启用。建议选择默认,即直接按回车。同时记录下有疑问的选项,以便下面再make menuconfig手工配置。仅在升级配置时使用。


第一次配置

代码: 第一次配置
$ cd /usr/src/linux
$ make defconfig
$ make menuconfig

make menuconfig这一步就是要修改硬件和文件配置。可能需要改动的主要有这么几个部分,分别是

  • CPU类型(默认是CONFIG_MK7)
  • IDE驱动(CONFIG_BLK_DEV_VIA82CXXX)
  • 网卡(CONFIG_E100)
  • AGP(CONFIG_AGP_VIA)
  • DRM(CONFIG_DRM_RADEON,建议不要启用,使用portage里的x11-drm)
  • Framebuffer(CONFIG_FB_RADEON)
  • 声卡(CONFIG_SND_VIA82XX)
  • 文件系统(只有CONFIG_EXT2_FS/CONFIG_[V]FAT_FS,ext3/reiserfs/xfs/jfs均未设置)
  • NLS CODEPAGE(需手工增加CONFIG_NLS_CODEPAGE_936)

以上括号里是默认配置情况。虽然不知道这是谁的配置,不过可以看出这个人的CPU是AMD的,主板是VIA的,显卡是ATI Radeon,只用ext2/fat32文件系统,且不是中文用户。

注意: 善用make menuconfig的搜索功能来搜索某选项(CONFIG_...)相关的菜单项的位置。如果你需要使用内核的其他功能,请参阅相关的官方文档或wiki,一般这样的文章里都有内核配置相关章节。如果实在不知道应该配置哪个选项,可以利用Linux内核配置档案

升级时配置

代码: 升级时配置
$ cd /usr/src/linux
$ cp /boot/config .config
$ make oldconfig
$ make menuconfig[可选]

编译和安装

代码: 编译和安装
$ make
$ make modules_install
$ make install
注意: make install时如已有同名文件,原文件会被改名,文件名后会添加一个.old。如果确认不需要保留这些旧文件,可以自行删除。

Read More...

星期一, 十二月 04, 2006

宝贝计划6号完美实施

宝贝计划归来
心里很高兴,非常感谢yn带给我的快乐
可是yn今晚牙不知道怎么回事
又开始疼了
真让人心里疼啊
yn快点好起来吧
我还等着你好起来一起自习呢



Read More...

星期五, 十二月 01, 2006

Internet Explorer 7 RC1 绕WGA的正确安装方法

Internet Explorer新闻主题Update:更新安装方法,成功安装.
利 用破解文件安装IE7 RC1的部分用户报告其系统出现故障,其故障出现在系统启动时提示normaliz.dll无法找到,初步估计是WGA破解有问题,cnBeta提供了一 份normaliz.dll供用户紧急处理,只要将该dll用各种方法复制到Windows XP的system32目录就可以解决.安装完毕后会没有Tab,但执行Update目录下的xmllitesetup.exe更新一下就可以了.




下载:normaliz.dll
下载:Internet Explorer 7 RC1 的WGA破解

1.先把IE 7 RC1的安装文件用WinRAR解开.
2.将破解iecustom.dll放进Update目录,覆盖原有文件.
3.执行update.exe安装
4.复制下载来的normaliz.dll到Windows的System32目录(必须执行,否则系统将故障)
5.重新启动.
6.执行Update目录下的xmllitesetup.exe更新一下就可以了

Read More...

星期四, 十一月 30, 2006

Beryl/AIGLX 3D桌面详细使用方法

全局选项:
Alt + 鼠标滚轮 上/下使窗口 透明/不透明

程序切换:
Alt + Tab:在当前工作台中切换窗口
Ctrl + Alt + Tab:在所有工作台中切换窗口

窗口排列(编排并显示所有窗口):上/下
左下角(关键区域):所有工作台(点击一个窗口缩放它到前台)
右上角(关键区域):当前工作台


显示桌面(看当前立体面的桌面):
右下角(关键区域):开/关

立方体旋转:
Ctrl + Alt + 左/右方向键:立体地切换桌面
Ctrl + Shift + Alt + 左/右方向键:把活动窗口移到左/右工作台
Ctrl + Alt + 鼠标左键并拖曳:手动旋转立方体

缩放:
Win + 鼠标右键:缩放一次
Win + 鼠标滚轮 上/下:手动缩放大/小

移动窗口:
Alt + 鼠标左键并拖曳:移动窗口
Ctrl + Shift + 鼠标左键:迅速移动窗口(会粘住边框)

调整窗口大小:
Alt + 鼠标中键

水波效果:
Ctrl + Win + 移动鼠标:关标在水上移动(默认无效)
Shift + F9:雨点降落在你的屏幕上

模糊效果:
在透明窗口下添加一些模糊(会使计算机变慢)

动画效果:
当创建或者关闭窗口时使用动画效果(对菜单也有效,不过你要选择“未知”,只选“菜单”没用)

反色效果:
Win + m:屏幕反色
Win + n:当前窗口反色

反射效果:
给装饰添加一些纹理(当透明时大多数可见)

屏幕截图:
Win + 鼠标左键并拖曳:将所选区域截图(图片保存在桌面)

焦点轨迹效果:
更旧的窗口更加透明

摆动效果:
使窗口、菜单等像棉花糖

亮度和饱和度:
Ctrl + 鼠标滚轮 上/下:增加/减少 饱和度(对桌面也有效)
Shfit + 鼠标滚轮 上/下:增加/减少 亮度(对桌面也有效)

窗口对齐:
Win + 小键盘1...9:在屏幕中快速对齐一个窗口(1=左下,2=中下,3=右下......)

Read More...

love u yn mm


my, originally uploaded by xuefengwang101.

呵呵,你知道的
gg一直喜欢你

Read More...

星期三, 十一月 29, 2006

让gentoo断点续编(译)?(转贴)

大概很多人都会遇到象我这样的烦恼:编译了一两个小时,程序因为一个依赖错误或者因为某个lib的问题导致编译错误,自己解决了问题之后再重新编译的时候又要重新开始。


在安装gentoo之前看手册的时候就知道有ccache这个选项,但当时只是介绍说是可以加速编译,今天搜索了一下才明白原来加速的原理就是“断点续编”,于是赶紧在自己的gentoo上也增加这个功能。具体方法如下:
代码:
#emerge -av ccache
#vi /etc/make.conf

在其中编译/增加如下两行:
FEATURES="ccache"
CCACHE_SIZE="2G"
当然啊CCACHE_SIZE的大小要根据自己的实际情况决定,如果硬盘太小,就不要设置这么大的空间给ccache了。

可以用这两个命令检查cchace的状态:
#emerge info | grep ccache
#ccache -s

任何手段都是双刃剑,在实际操作过程中可能要注意的一个问题:有时候因为某种原因导致的编译失败,下次还是会读取失败的cache,因此每次都失败。出现这种情况的话,删除/var/tmp里面的ccache目录再重新编译就行了。

Read More...

星期二, 十一月 28, 2006

和yn游泳

呵呵今天和yn一起游泳了
这是第一次和mm游泳
感觉真开心啊,以前怎么叫她都不去
现在怕我去看别的女生主动和我去游泳了
呵呵
近距离和mm贴着,感觉真是妙极了
趁机还欺负了她几下
好好玩
估计yn看到了就生气了
呵呵

Read More...

星期一, 十一月 27, 2006

如何在帖子中添加代码

有时候我们需要在帖子中展示一些源代码,如果在Blogger的编辑器中,这些代码就会被执行。这时候,最简单的方法就是通过一些离线Blog撰写 软件,这是鱼喜欢上Windows live writer的主要原因,几乎省下了以前一半的时间。现在Windows live writer存在的缺点就是不能为Blogger beta加标签以及上传图片,写完之后还要重新到Blogger中加上标签。

再者就是通过一些网页编辑软件比如Dreamweaver转换,也非常方便。鱼之前就用这种方法。

以上两种方法适宜大量的代码,如果只是几句简单的代码大可不必这么麻烦。只要把"<"用“<”代替,“>”用“>”代替即可。

或者我们也可以创建一个Text区域来显示代码
<br /><center><form><textarea rows="3" cols="50" readonly>代码部分</textarea></form></center><br />

Read More...

Linux终端下如何实现彩色Shell输出

http://cn.tech.yahoo.com/050531/55/26zyr.html

对于兼容ANSI的终端,如xterm、rxvt、konsole等,可以彩色显示终端文本中的底色或前景颜色,本文将详细讨论如何实现随意修改和定制这些终端的颜色。

每个Linux用户几乎天天都会面对Bash,刚接触Linux的人总是感觉Bash过于沉闷单调,但是实际上每个用户都可以根据需要定制出自己喜欢的Shell,使它变得丰富多彩。例如,彩色提示符就可以使终端更酷,并且与众不同。



  由于Linux中使用最广泛的Shell就是Bash,因此我们在这里主要讨论Bash,希望在其它不同Shell中定制色彩的可以参考Man。

  配置Shell

  设置颜色可以在Linux用户个人的Shell配置文件~/.bashrc中完成,或者在全局配置文件 /etc/bashrc中实现。这时候所有用户都会拥有一个一样的登录彩色Shell,其中提示符设置是由bashrc文件中的PS1变量来控制的,例如 可能是如下的格式:

  ~/.bashrc: PS1="s-v$ "

  这里"s"表示Shell的名字,"v"表示Shell的版本号,在最后提示添加一个"$"美元符号。这样,当该用户登陆以后,得到的提示符就如下所示:

  -bash-2.05b$

  由于这样的提示符并不能提供足够的有意义信息,例如当前所在目录等,因此在绝大多数Linux发布中,提示符往往被设置为如下所示:

  ~/.bashrc: PS1="[u@h W $] "

  这就是我们熟悉的[username@hostname current_dir $]的提示符模式。

  转义序列符

  为了添加个人风格的彩色提示符,我们需要使用转义序列符。一个转义序列符是一个控制命令,它控制Shell执行某个 特定的动作。一个转义序列符通常以 ESC开始,在Shell中被记录为"^[",有时候也被常常记录为3(因为ESC在ASCII编码中是27,八进制就被记录为033)。

  为了直接在Shell中输入一个转义序列符,一般会以“Ctrl+V”作为前导,也就是“Ctrl-v ESC”。

  使用Shell颜色

  首先使用一个例子来说明如何实现Shell彩色:

  PS1="[ 3[0;32;40mu@h:w$ 3[0m ]"

  这时候就会显示如下的提示符:

  在上面命令中,“3[0;32;40m”表示定义后面文本的颜色,“3”表示启动一个转义序列,“[”定义开始颜色 定义,“0”定义默认的字体颜色,其它部分稍后定义。“32”定义文本的前景色,这里32表示绿色;“40”定义文本的背景色,40表示黑色。在字符串的 最后定义了“ 3[0m”,它是用来恢复了默认的文本颜色设置,这样就只会得到一个彩色提示符,而不会影响命令和其输出的颜色显示(即黑底白字)。

  我们一共有8种字体颜色可供选择,它们分别是30 (黑色)、31 (红色)、32 (绿色)、33 (黄色)、34 (蓝色)、35 ( 紫红色)、36 (青色)和37 (白色)。对于底色也有8种颜色可供选择,只需要将字体颜色的3修改为4即可,例如40、41、42、43、44、45、46、47。

  例如,运行下面命令:

  ~/.bashrc: PS1="[3[0;37;44mu@3[0;32;43mh:3[0;33;41mw$3[0m]"

  将显示如下彩色提示符:

  或者

  PS1="[3[1;34;40m[3[1;31;40mu@h:w3[1;34;40m]3[1;37;40m $3[0;37;0m] "

  将显示如下彩色提示符:

  文本属性

  我们前面提到,转义序列符后面的“0”表示定义文本的颜色设置。除了颜色设置以外,还可以设置文本的其它属性。转义 序列符后可以跟以下数值:0、1、 22、4、24、25、7、27,分别定义颜色、黑体、非黑体、下画线、非下画线、闪烁、非闪烁、翻转、非翻转。通过下面的脚本我们可以看到所有的效果:

#!/bin/sh

############################################################

# Nico Golde Homepage: http://www.ngolde.de

# Last change: Mon Feb 16 16:24:41 CET 2004

############################################################

for attr in 0 1 4 5 7 ; do

echo "----------------------------------------------------------------"

printf "ESC[%s;Foreground;Background - " $attr

for fore in 30 31 32 33 34 35 36 37; do

for back in 40 41 42 43 44 45 46 47; do

printf '3[%s;%s;%sm %02s;%02s ' $attr $fore $back $fore $back

done

printf ' '

done

printf '3[0m'

done

  在Shell环境下设置颜色的能力,不仅仅能够使得Shell提示符看上去更丰富多彩和吸引人,而且能有助于帮助基于console的Linux程序的互动性和趣味性。

  来源:《开放系统世界》 作者:李翔

Linux 终端机下的彩色显示
(2001-04-27 15:20:29)
作者: Thorbjørn Ravn Andersen, ravn@dit.ou.dk
译者: Chou-Kai Wang, stylon@ms2.hinet.net
v1.4, 7 August 1997 


--------------------------------------------------------------------------------
虽 然大部份的 Linux 发行版本都附有一个用来把目录的内容列出来,而且可以利用彩色来增强输出在视觉上的效果的'ls'指令,不过要把他设定的合你意 却不是件容易的事。这份文件说明了设定一些已经内附在你的 Linux 发行版本的软体,来达到这个目地的好几种不同的方法,还有在那□可以找到一些在大 部份版本的 Unix □都会用到,但是却常常不被附在 Slackware 或 RedHat Linux □的软体。这份文件的 HTML 版本也可 以在我的原始档案这□ http://www.mip.ou.dk/~ravn/colour-ls 找的到。 
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

1. 简介
这些年来彩色的显示器已经相当普遍,使用者也开始使用一些以彩色来表示例如:程式语言□的保留字,或是拼错的字,来给使用者一些视觉上的回馈。 

自 从 Linux 的文字模式控制台支援彩色後,原来的 GNU ls 也很快的被修改成支援输出彩色的讯息而且被附在 Slackware 2.0 版 □。这些改良原来版本的缀补档案已经被整合到标准版的 GNU ls 里,现在也应该是所有新的 Linux 发行版本的一部份了。 

现在这版本的文件是把最初的版本改写了许多部份後更新而来的,包括了一些关於 xterm 和 如何利用缀补档来更新核心的资讯。 

这 份文件里的资讯都在 Redhat 4.1 □验证过,而且主要是在Slackware 2.0.2 版及核心版本 1.1.54 的环境□搜集而来的。 核心的缀补档的资讯是在 slackware 2.2.0,1.2.13 版的核心,并且以 tcsh 为预设的 shell的环境□取得的,而後来也在  2.0.27 的核心□验证过。如果你使用其它的设定或是 unix 版本,我会很感激你告诉我你的作业系统及版本,还有它是否支援彩色的显示。 



--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

2. 快速入门:给没有那麽多耐心的读者
如果你有个 新版的 Linux,对你使用者目录下的这些档案作这些修改,下次你登入的时候就会生效了。 


~/.bashrc:
    alias ls="ls ‐‐color"

~/.cshrc:
    alias ls 'ls ‐‐color'
    

这样就好啦! 
你 也许还会想要作:``eval `dircolors $HOME/.colourrc`'',来设定你自己想要的颜色。这个档案可以用  ``dircolors -p >$HOME/.colourrc'' 来制造出来,而且□面有许多的注解方便你更改设定。 



--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

3. 这样就好了吗?

首先你需要知道你使用的 ls 是不是可以适当的处理彩色输出。在 Linux 的文字模式控制台试试看这个指令(在 xterm □也可以): 


% ls ‐‐color

(这□的 % 是 shell 的提示符号): 

如果你看到了表示你的 ls 不能接受这个选项的错误讯息,那你应该安装新版本的 GNU fileutils 软体。如果你使用的发行版本没有提供新的升级软体,那麽就从 GNU 的映射站台取得这个软体并且直接从原始码安装。 

如果你并没有看到错误讯息,那麽你使用的 ls 便可以接受这个选项。但很不幸的,有一些在 Slackware (其它的发行版本也有可能) □附的早期版本是有臭□的。在 Redhat 4.1 □面附的 3.13 版的 ls 就没有问题。 


% ls ‐‐version
ls - GNU fileutils-3.13

如果你在 Linux 的文字模式终端机□执行 ``ls ‐‐ color'',那麽它的输出应该依照系统的预设值而有适当的彩色,而且你现在可以开始决定是不是需要改变任何的设定。 

如 果你在 xterm □执行上面的过程,也许你还是没办法看到输出变成彩色。就跟 ls 一样,原来的 xterm 并不支援应用程式的彩色输出,而较新 的版本有支援。如果你的 xterm 不支援彩色,那麽请参考这个文件的结尾拿到较新版本的 xterm,同时你也只好切换到文字模式并且继续下面的步 骤。 



--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

4. 有那些颜色可以选择呢?
下面的 shell 命令稿(感谢许多把 bash 的版本寄给我的人)显示出现在使用的主控台能够支援的各种颜色组合。如果没有颜色出现,那麽你的主控台就不支援 ANSI 的颜色选择。 


#!/bin/bash
# 显示 ANSI 的彩色
#
esc="\033["
echo -n " _ _ _ _ _40 _ _ _ 41_ _ _ _42 _ _ _ 43" 
echo "_ _ _ 44_ _ _ _45 _ _ _ 46_ _ _ _47 _"
for fore in 30 31 32 33 34 35 36 37; do
  line1="$fore  " 
  line2="    "
  for back in 40 41 42 43 44 45 46 47; do
    line1="${line1}${esc}${back};${fore}m Normal  ${esc}0m"
    line2="${line2}${esc}${back};${fore};1m Bold    ${esc}0m"
  done
  echo -e "$line1\n$line2"
done

前景的颜色号码是在左边那一排,背景的则是在上方。如果你要粗体的字元和高亮度就在参数□加一个 "1",所以前景是白色而背景是蓝色就成了 "37;44;1"。整个的 ANSI 颜色选择序列就是 

ESC [ 3 7 ; 4 4 ; 1 m

。 
注: 背景不可以是高亮度,所以黄色(高亮度的棕色)只能用来作前景。这是硬体上的限制。 


颜色代码:
        0 - 黑色     4 - 蓝色           3# 是背景颜色
        1 - 红色     5 - 粉红色         4# 是前景颜色
        2 - 绿色     6 - 青色
        3 - 黄色     7 - 白色           ;1 是粗体和高亮度



--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

5. 如何设定 ls 的彩色输出

如果你想要修改 ls 内定的标准颜色,你需要用下面的指令在你的 HOME 目录下制造这一个档案 

 cd ; dircolors -p > .coloursrc 

在你编辑完这个注解的很详细的档案以後,你必需要把它读进你的环境变数 LS_COLORS □,通常都是这样作的 

eval `dircolors .colourrc`

然後你要把前面这一行放进你的 .bashrc 或 .cshrc 或 .tcshrc (依照你使用的 shell 而定)□。更详细的用法请看 dircolors(1) 的使用说明。 



--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

6. 如何改变系统的预设值: 前景白色而背景是黑色


你需要告诉你的终端机驱动程式你想要的另一个预设值。要如何作并没有一个标准的方法,不过如果你是用 Linux 的话,你有 setterm 这个程式可以用。 


"setterm" 使用终端机资料库□的资料来设定属性。要选择属性的话要这样作 

setterm -foreground black -background white -store


"-store" 参数把现在所作的改变设定成预设值。这需要你现在使用的的终端机种类(在 TERM 环境变数□)在 termcap 资料库□有足够详细的纪录。如果 setterm 因为某种因素不能正常的工作,你还有其它的选择。 



6.1 Xterm 

你要有至少一种下列的 xterm,而且要支援彩色。 


xterm -fg white -bg blue4
color_xterm -fg white -bg blue4
color-xterm -fg white -bg blue4
nxterm -fg white -bg blue4

这□的 'color_xterm' 支援彩色版的 'ls'。这□的颜色选择是模彷 SGI 上面使用的颜色。 


6.2 虚拟主控台 

你也可以修改核心,这样就可以一劳永逸的用控制码来改变虚拟主控台的预设值。如果你自己编译核心的话,我建议利用 kernel 的缀补档。 


核心的原始码是在 /usr/src/linux/drivers/char/console.c ,大概在 1940 行,这是你应该修改的地方 


        def_color       = 0x07;   /* white */
        ulcolor         = 0x0f;   /* bold white */
        halfcolor       = 0x08;   /* grey */

        def_color       = 0x17;   /* white */
        ulcolor         = 0x1f;   /* bold white */
        halfcolor       = 0x18;   /* grey */

这 边的十六进位数字是给显示卡用的: 最左边的位元(上面□例的 "1")是背景 ; 最右边的位元是前景。0 = 黑色,1 = 蓝色,2 = 绿色,3  = 青色, 4 = 红色, 5 = 紫色,6 = 棕色/黄色,7 = 白色。把数字加 8 可以得到高亮度的颜色。在大部份的情况下,高亮度的背景 色 == 闪烁的字加上普通的背景。由 sjlam1@mda023.cc.monash.edu.au 所提供 


你也可以使用下面的 ANSI 控制码提供一个执行时期的主控台预设值。(在核心原始码□找到的) 

        ESC [ 8 ]

这个控制码把预设值设成目前的前景及背景颜色。然後重设属性的控制码(ESC [ m)让这预设值马上就取代黑白色成为使用中的颜色。 

每次你重开机的时侯你都需要再把这些字串送给主控台。依照你的 Linux 主机用途不同,有好几个档案可以达成这个目的。 


/etc/issue


在  Slackware □这就是 "Welcome to Linux xx.yy" 讯息所在的档案,如果你的主机是个人使用的话,从这个档案下手是不 错的选择(但对於用 telnet 远端登入使用系统的人就可能有点讨厌)。这个档案在每次开机的时侯都会被制造出来,原来的内容则被覆盖,所以你必需要 修改开机档案(在 Slackware □是 /etc/rc.d/rc.S,Redhat□是 /etc/rc.d/rc.local)□面的下列几 行: 


  echo ""> /etc/issue
  echo Welcome to Linux `/bin/uname -a | /bin/cut -d\  -f3`. >> /etc/issue

改成 
  ESCAPE="在这□放入 ESC 码"
  echo "${ESCAPE}[H${ESCAPE}[37;44m${ESCAPE}[8]${ESCAPE}[2J"> /etc/issue
  echo Welcome to Linux `/bin/uname -a | /bin/cut -d\  -f3`. >> /etc/issue

这□ 的控制码会把游标归位、设定颜色(在这□的前景是白色而背景是蓝色)、把这个设定存起来并且把萤幕上其它部份清除掉。这□的改变会在下次重开机时生效。别 忘了在 emacs 要打入 ESC 字元要按 C-q 键而在 vi □要按 control-v,因为很显然的执行以上程式的 sh 并不了解  /033 这种用法。 


/etc/profile 或 .profile

  if [ "$TERM" = "console" ]; then
      echo "\033[37;44m\033[8]" #
# 或使用 setterm。
      setterm -foreground white -background blue -store
  fi


/etc/login 或 .login


  if ( "$TERM" == "console" ) then
    echo "\033[37;44m\033[8]"  
# 或使用 setterm。
      setterm -foreground white -background blue -store
  endif

[ 译者注: Linux 的主控台下的 $TERM 环境变数已经是 "linux" 而不是 "console" 了 ] 


6.3 远端登入 

你应该可以用上面示□过的 setterm 程式。当然,远端的机器必需要能够得到足够的资讯来操作你的终端机,而且你的终端机模拟程式要能够支援彩色。在我的经验□其它平台上最好的 vt100 终端机模拟程式有下列几种: 

MS-DOS: MS-Kermit (免费, 不是 Microsoft 的产品) 
Windows 95/NT: Kermit/95 (共享软体) 
OS/2: Kermit/95 (共享软体)。 请注意标准的 telnet 支援彩色而且可以在本地端设定。 
关於 kermit 的细节请看 http://www.columbia.edu/kermit/ 




--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

7. 软体

以上所有的用法都假设你使用的是 GNU/Linux。如果你是使用其它的作业环境(比如说是执行 X 的 Sun 工作站等等)你还是可以拿到并且自己编译这些软体。 

彩色版的 xterm 是从标准的 xterm 原始码而发展来的,而用来修改标准 xterm 的缀补档可以从任何一个 X11R6 的站台获得。听说 R6.3 内附的 xterm 有支援彩色,不过我没有测试过。 


ftp://ftp.denet.dk/pub/X11/contrib/u...R6pl5-patch.gz

如果你是用旧版的 X 的话请看内附的文件。注意: 我自己并没有测试过! 

'ls' 是内附在 GNU 的 fileutils 软体□而你可以从 prep.mit.edu 或其它的映射站台拿到。请拿最新的 3.13 版本。 

ftp://ftp.denet.dk/pub/gnu/fileutils-3.XX.tar.gz


我自己曾经在 Solaris,SunOS,Irix 上成功编译过 color-ls。 


我很欢迎对於这篇文章的回应。我的电子邮件地址是 ravn@dit.ou.dk

‐‐ 

Thorbjørn Ravn Andersen 


--------------------------------------------------------------------------------

Read More...

星期日, 十一月 26, 2006

学习好累阿!

今天不知道为什么,学习的特别累
真是郁闷
不过还好坚持到十点回来
真不知道接下来的日子怎么办
bless
谢谢yn对我的鼓励

Read More...

星期六, 十一月 25, 2006

Using ‘until’ with portage

Have you ever updated your world or system and walked away only to come back several hours later to find out the update did not complete because a package failed?

The following simple command list and bash ‘until’ command will let you update your world or system to completion and skip those packages that failed:

Code Listing 3.1: Using until to skip broken packages


# sudo emerge -DNu world ||
# until sudo emerge --resume --skipfirst; do
# sudo emerge --resume --skipfirst; done

Once the command list completes, you can find out which packages failed by running the following command:

Code Listing 3.2: Checking for failed packages

# emerge -Dup world

Warning: Under certain circumstances, this can yield an unusable system. Always check the output of emerge -Dup world prior to using this tip.



Read More...

星期四, 十一月 23, 2006

yn妹妹多来看看

今天写新的blog了
希望yn妹妹能多来看看gg
呵呵
原来那个感觉规模比较小
速度也不好
还是把家先安到这里吧

Read More...

星期三, 十一月 22, 2006

emerge的一些技巧

1、升级用emerge -avuND world。(相当于--ask --verbose --update --deep --newuse world)。如果用-pv,之后还要再计算一次依赖关系。经常升级系统的话,就用-a就行了,看看有没有实在不能去升级的东西(一般没有),没有就 Yes,比较方便。

2、出现已安装的包被block的情况,可能无法升级,这时候检查一下升级的包的列表,应该是有一个新的包block了这个包,而这个新的包又是依赖于被block的包的升级版的。解决办法是emerge -C被block的包,之后update就能解决问题。

3、如果想有Debian/Ubuntu的Synaptic一类的直接一些的portage图形前端,可以试试emerge kentoo。Kentoo的用法比较简单,看看就会了。


4、显示emerge程序所用时间的软件:emerge genlop。之后就可以用genlop –t –l来显示之前emerge的软件都用了多少时间。Genlop还有很多其他的功能,可以man一下认真看看。

5、emerge一个软件的时候加-t (--tree)参数可以显示完整的依赖关系。

6、有软件出现“masked by missing keyword”的时候,可以自己在/etc/portage/package.keywords里面给它指定keyword,比如*或者~*。*的意思 是满足任何stable的keyword,~*意思是满足任何unstable的keyword。

7、有时候装一些大型软件,比如emerge gnome的时候,world里面只记录了gnome一个关键字,却没有记录相关的依赖关系,因此升级world的的时候,一些包可能得不到合理有效的维 护。解决办法是用regenworld这个命令来全面更新world的记录。Regenworld的原理是用你的emerge.log来重新生成 world记录(LiveCD安装的预套件似乎也不行?)。如果因为某些原因emerge.log也不能解决world的问题,可以参考这个贴子用 qkpg或者equery等gentoolkit提供的工具去解决:http://forums.gentoo.org/viewtopic.php?t =136627

8、比emerge –search更快的查询软件:eix。可以通过emerge eix来安装,用update-eix来更新查询的cache。运行eix-sync可以有emerge –sync同样的更新效果,还可以同步更新eix的cache记录。

9、几个常用的命令和文件的范例(一看就明白):
echo media-video/realone >> /etc/portage/package.unmask
echo net-p2p/bittorrent -X >> /etc/portage/package.use
echo sys-kernel/linux-headers -* >> /etc/portage/package.keywords
world的记录: /var/lib/portage/world
mask文件的记录:/etc/portage/package.mask
自安装的非portage软件记录:/etc/portage/profile/package.provided

Read More...