最近想折腾用texlive写点东西,而且要支持中文。就冲着texlive-2009了。大学毕业论文就是用latex写的,不过那是在Windoews下,用CTEX包,很是方便,Gentoo就有点不一样了。虽然texlive有自己的iso镜像,有自己的安装工具和包管理工具,但Gentoo还是将它拆分成了很多的packge来装。这样也好,比较灵活。

下面就开始吧。

首先是keywords和use,因为现在2009还不稳定,而我用的是x86就要增加一堆的keyword,如下:

app-text/texlive ~x86
app-text/texlive-core ~x86
dev-texlive/texlive-documentation-english ~x86
dev-texlive/texlive-documentation-base ~x86
dev-texlive/texlive-basic ~x86
dev-texlive/texlive-bibtexextra ~x86
dev-texlive/texlive-context ~x86 Continue reading »
 

emerge一个软件包时Portage的工作方式:
1,Portage下载源码tar包和补丁(如果需要的话)
2,Portage解压缩tar包到指定位置,所有的编译将在该目录展开,Portage默认使用/var/tmp/portage/packagename/work
3,解压和打补丁(如果需要的话)后(ebuild中的src_unpack()函数),Portage开始编译,一般情况下在特定目录(ebuild使用${WORKDIR}变量指定目录)下执行configure和make命令.
4,编译完成后,portage将所有指定目录下的文件合并到正在运行的系统中.(通常为/,但通过合并时设置ROOT=”/路径”可以修改),为了避免非法或不正确的ebuild对整个文件系统造成不可逆的破坏,我们需要严格限制文件系统的哪个区域允许portage在解压和编译时修改,这就是沙盘工作的路径,默认时,沙盘启动,并限定ebuild(和它执行过程中的明林)都在指定的区域内写磁盘.若ebuild越过沙盘保护的环境,试图在外部区域写磁盘,就构成了沙盘越界.
Continue reading »

 

先来介绍一下n32和O32是啥,N32和O32就是MIPS系统上不同的ABI,即Application Binary Interface。MIPS体系结构最早只有o32的系统,但后来改进了寄存器的功能和分配方式,于是就又有了N32,相对于O32,N32的速度更快些。但二者目前在龙芯系统上还无法兼容。因为龙芯目前官方只支持O32,而N32有只有zhllg的overlay中有,所以使用gentoo来安装O32的工具链需要额外解决些问题,所以才有了这篇文章,之所以之前又写了N32的安装方法,是因为有zhllg大牛的技术支持,使得能直接安装N32的工具链。 Continue reading »

 

折腾了半天的ebuild,将记录张贴如下:

  • ebuild 包含下载,解压,编译安装包的全部信息,还有卸载和配置内容。大多数ebuild用bash脚本编写。简单来说就是一个Portage系统的底层z直接接 口,它可以通过命令执行ebuild文件中提供的子功能。包括下载源码包(fetch),解压(unpack),配置(configure),编译 (make),安装目标文件(install)甚至包括重新打包为二进制压缩包(package)
  • 例如,以我现在正在安装的cross-mips64el-unknown-linux-gnu/gcc为例,需要使用gcc-4.4.2.ebuild。运行 ebuild gcc-4.4.2.ebuild help 会得到能执行的命令,如下 Continue reading »
  •  
  • 什么是Crossdev[I]
  • sys-devel/crossdev
    Available versions: 0.9.18-r10 ~0.9.19 **99999999
    Installed versions: 0.9.18-r10(03:44:50 PM 11/29/2009)
    Homepage: http://www.gentoo.org/
    Description: Gentoo Cross-toolchain generator

    交叉编译时很多嵌入式开发必须的工具,因为资料太少,遇到的问题又很难解决,所以交叉的开发环境一直让很多程序员头疼。我们就来了解一下gentoo下如何构建交叉编译环境。
    先说说工具链,工具链是用来组建一个系统的工具包集合,因为它们使用输入和输出连接在一起,所以称为链。通常工具链包括以下几部分: Continue reading »

     

    原文是英文wiki里Dealing with masked packages那篇
    http://gentoo-wiki.com/TIP_Dealing_with_masked_packages
    感觉这篇很重要,在wiki里做为TIP类,自然表示可以带来很多方便,特别是后面那几个脚本
    早就想翻译这篇了, 一直没动手,眼看下周就要开学了,要忙开学的事情。
    所以今天赶紧把它译了出来 里面有一些专有词汇 如有问题请大家指正

    —————————————————————————————————————–
    相关连的那篇也翻译了: Package.keywords的小技巧
    原文 http://gentoo-wiki.com/TIP_package.keywords

    同步的中文wiki http://zh.gentoo-wiki.com/Package.ke…8A%80%E5%B7%A7

    wiki里这两篇文章的相关联系已经更新
    ————————————————————————————————————————
    其他更新
    HOWTO 用Cedega运行极品飞车9 http://zh.gentoo-wiki.com/HOWTO_%E7%…3%9E%E8%BD%A69
    原文: http://gentoo-wiki.com/HOWTO_RUN_Nee…ed_with_Cedega

    ——————————————————————————————————————————

    处理被屏蔽(masked)的包

    本文内容:
    介绍
    被关键字(keyword)屏蔽(masked)的包
    被不明的关键字屏蔽
    被严格屏蔽(Hard masked)的包
    手动进行严格屏蔽
    编辑/etc/portage/package.keywords文件的简便方法
    开放一大群有联系的包

    介绍
    首先,被关键字(keyword)屏蔽(masked)的包都是测试中的或者不稳定的包:
    注意: "(masked by: ~keyword)"
    Masked By ~keyword Package Example

    代码:
    # emerge gnome-extra/gdesklets-core '''Calculating dependencies''' !!! all ebuilds that could satisfy "gnome-extra/gdesklets-core" have been masked. !!! possible candidates are: - gnome-extra/gdesklets-core-0.26 (masked by: ~keyword) - gnome-extra/gdesklets-core-0.26.1 (masked by: ~keyword) !!! Error calculating dependencies. Please correct.

    其次,被严格屏蔽(Hard masked)的包:
    注意: "(masked by: package.mask)"
    Hard Masked Package Example

    代码:
    # emerge -pv filewatcher These are the packages that I would merge, in order: Calculating dependencies !!! All ebuilds that could satisfy "filewatcher" have been masked.!!! One of the following masked packages is required to complete your request:- app-admin/filewatcher-2.4.0 (masked by: package.mask)# Elfyn McBratney <beu@gentoo.org> (28 Apr 2005)# Masked for testing.

    如果你仍然想安装这些包,那该怎么办呢……

    被关键字(keyword)屏蔽(masked)的包

    现在的新方法是:

    echo "gnome-extra/gdesklets-core" >> /etc/portage/package.keywords
    或者

    echo "=gnome-extra/gdesklets-core-2.10.9" >> /etc/portage/package.keywords

    如果你想开放一个特定的版本。

    注意:你不需要在package.keywords里面指明电脑架构,除非你想使用其他架构中的软件,当然这是不推荐的。

    如果emerge指示某个软件包被 "~* keyword"屏蔽, 你需要逐字的把他写下来,例如:

    echo "~gnome-extra/gdesklets-core-2.10.9 ~*" >> /etc/portage/package.keywords

    如果你在用crossdev为多种架构建立软件包,例如:

    echo "~gnome-extra/gdesklets-core-2.10.9 ~*" >> /etc/portage/package.keywords/cross-i686-pc-linux-gnu

    OSB: 在cross-i686-pc-linux-gnu中i686-pc-linux-gnu的名字要根据各架构做相应改变。

    到此,在做了以上任一步骤后,需使用一下命令编译这个包:

    emerge =gnome-extra/gdesklets-core-2.10.9

    关于package.keywords这个文件的更多信息请点击这里http://zh.gentoo-wiki.com/Package.ke…8A%80%E5%B7%A7.

    如果你在命令行模式下,app-portage/flagedit是自动向packages.keywords里面添加项目的工具。

    使用实例:

    代码:
    flagedit gnome-extra/gdesklets-core -- +~x86

    Kuroo是一个有用的KDE程序,可以让你浏览portage树并且对任何包进行指定安装。

    它使你能安装具有任何依赖性的包,但是,这个程序目前由于不稳定而被屏蔽,比如 ~x86, 所以你不能安逸的在实际安装中使用它(即使它只是portage的前端)。

    即使你不想把kuroo用于实际安装,但在开放依赖包时你还是需要它。

    代码:
    emerge -pv kuroo

    它编辑标准的portage文件。

    旧方法 (不提倡)

    ACCEPT_KEYWORDS="~x86" emerge gnome-extra/gdesklets-core

    这种方法已经不被提倡了,它出现在这里仅仅是因为历史原因,不要用这个方法。
    请阅读http://forums.gentoo.org/viewtopic.p…060314#1060314 这是关于为什么ACCEPT_KEYWORDS不好的帖子。

    简而言之,是因为emerge -u world会对用ACCEPT_KEYWORDS安装的包降级,这会造成潜在的致命改变并且使你的系统陷入瘫痪。
    -U(功能:仅仅升级)这个参数也不被提倡了,这有一个充分的原因:如果包坏了,portage应该使它降级,-U确会对此操作造成阻碍。

    被不明的关键字屏蔽

    在你试图安装一个没有在你的架构上测试过的软件时,这个问题很常见。
    向package.keywords文件中,在你要安装的那个包后面加"~*"以开放这个包。 例如:

    echo "net-ftp/vsftpd -* ~*" >> /etc/portage/package.keywords

    如果你有被9999屏蔽的CVS包,你可以做如下操作:

    echo "media-gfx/retina **" >> /etc/portage/package.keywords

    牢记,如果你在一个没有测试个架构里安装软件,这个软件也许没法运行。

    被严格屏蔽(Hard masked)的包

    开放被严格屏蔽(Hard masked)的包,需要把它们加到/etc/portage/package.unmask文件中。
    所用命令和package.keywords稍有不同:

    echo "=app-admin/filewatcher-2.4.0" >> /etc/portage/package.unmask

    这将开放2.4.0版的app-admin/filewatcher。 如果你想开放这个包的所有版本,仅仅写它的名字就行了:

    echo "app-admin/filewatcher" >> /etc/portage/package.unmask

    当然也可以像 http://gentoo-wiki.com/TIP_package.keywords 里面那么操作。

    注意:由于这些包的不稳定性,被严格屏蔽的包一般也被同样关键字被屏蔽。 你多半须要向package.unmask和package.keywords中都加人这个包。

    手动进行严格屏蔽

    很少的情况下,你需要避免这些包的安装。
    这也许是个例子,如,某软件ebuild脚本里的一个bug造成那个包在你的系统上编译失败,这会使得像emerge –update –deep world这类命令无法顺利执行。

    你可以跳过那个包的ebuild,这是通过把它的名字加到/etc/portage/package.mask来实现的:

    echo "=sys-apps/file-4.17-r1" >> /etc/portage/package.mask

    所用命令和上述package.unmask的一样。

    编辑/etc/portage/package.keywords文件的简便方法
    flagedit
    # 安装: emerge flagedit
    # 使用: flagedit <atom> — +<keyword>,例如 flagedit dev-util/libconf — +~x86
    gimme
    这个脚本使编译那些被关键字~arch屏蔽的包变得简单

    /usr/bin/gimme

    代码:
    #!/bin/bash ############### gimme version 0.5.4 ################# Script to add package names to package.keywords. ## Originally by Tekmanx, re-written by Hackeron ## re-re-written by Gherald and edited by D. Watzke ##################################################### source /sbin/functions.sh [[$EUID != 0]] && { eerror "You are not root!" exit 1} [[-z "$1"]] && { eerror "Please specify a package name (eg. gimme <package-name>)" exit 1} [[-d /etc/portage]] || mkdir -p /etc/portage # Get fully-qualified ebuild nameFQN=$(ACCEPT_KEYWORDS="~x86" emerge -p $1 | grep "$1" | grep 'ebuild ' | tail -n2 | \head -n1 | sed -e 's/\[ebuild.......\]\ //' -e 's/\[[[:digit:]].*\]//' -e 's/-[[:digit:]].*$//') # We think there is either none or more than one package matching $1# so we let the user deal with it [[-z "$FQN"]] && emerge $@ -a; exit if grep -q "^ *[\>\<=]*$FQN *" /etc/portage/package.keywords; then ewarn "/etc/portage/package.keywords already contains \"$EXISTING\"" emerge $@ -a; exitelse einfo "Adding $FQN to package.keywords and emerging in 5 seconds."; sleep 5 echo $FQN >> /etc/portage/package.keywords emerge $@ -afi

    把这个文件命名为"gimme"并保存到/usr/bin/然后执行:

    chmod 755 /usr/bin/gimme

    现在你就可以使用这个脚本了,例如:

    gimme gdesklets-core

    /etc/portage/package.unmask的脚本

    这个脚本使开放那些被严格屏蔽的包变得简单。
    /usr/local/bin/unmask

    代码:
    #!/bin/bash## This script will unmask any package masked by the actual profile.## First we search for what is actually masked # in /usr/portage/profiles/package.mask then add a corresponding # line in /etc/portage/package.unmask### Original by drax@sweon.net source /sbin/functions.sh [ "$UID" -ne "0" ] && eerror "You must be root to run this script." && exit[ -z "$1" ] && eerror "Please state a package name (eg. unmask kde-base/kode)" && exit[ ! -d /etc/portage ] && einfo "Creating /etc/portage directory" && mkdir /etc/portage if [ "$(grep "$1"-[0-9] /etc/portage/package.unmask 2>/dev/null)" ]; then ewarn "$1 already exists in package.unmask"else PKG_LINE="$(grep "$1"-[0-9] /usr/portage/profiles/package.mask 2>/dev/null)" if [ ! $PKG_LINE ]; then PKG_LINE="$(grep "$1" /usr/portage/profiles/package.mask 2>/dev/null)" fi if [ ! $PKG_LINE ]; then ewarn "Could not find $1 in /usr/portage/profiles/package.mask" && exit 1 else ebegin "Adding $1 to package.unmask" echo $PKG_LINE >> /etc/portage/package.unmask eend $? fifi

    同样,把这个文件命名为"unmask"并保存到/usr/local/bin然后执行:

    chmod 755 /usr/local/bin/unmask

    现在你就可以使用这个脚本了,例如:

    unmask kde-base/kode # this version of unmask requires the full package name, including app-category/

    也可以配合gimme一起使用,例如:

    unmask kde-base/kode && gimme kode

    潇洒去吧

    开放一大群有联系的包
    从Portage 2.1起,很多/etc/portage/package.*的文件能够被目录代替。这些目录里的文件可以自动被Portage连结在一起。

    这个对于X模块(xorg)来说特别有用,几乎300个的和这个模块有联系的包都需要被开放。因而,你可以复制 http://www.gentoo.org/proj/en/deskto…x-packages.txt
    到/etc/portage/package.keywords/xorg (也许同样需要复制到 /etc/portage/package.unmask/xorg)。如果不这样的话/etc/portage/package.keywords里会 有一大窜东西,而使得这个文件不好管理。

    脚本:开放所有被依赖的包

    /bin/gimme-everything

    代码:
    #!/bin/bash## This script will unmask any package masked by specified keyword## It is using flagedit to remove keyword# Usage: /bin/gimme-everything "=gnome-2.14.2" "+~amd64"# Sorry that this is in one command line, but it was composed in one ;)## author: mmazurek[at]wallix.com while true; do if emerge "$1" | grep '!!! All ebuilds'; then emerge "$1" | grep '!!! All ebuilds' | while read line; do n=$(echo $line | sed -e "s/.*\"\(.*\)\".*/\\1/"); flagedit "$n" -- "$2"; done; else break; fi;done

    脚本:开放所有被依赖的包 2
    这个脚本不需要flagedit.
    /sbin/unmask

    代码:
    #!/usr/bin/perl -wuse strict; sub emerge{ my $package = shift; $_ = `emerge -pv "${package}" 2>&1`; if(m/^- (\S+) \(masked by:.*package.mask/mi) { print "Unmasking ${1} in package.unmask\n"; print UNMASK "=${1}\n"; return 1; } if(m/^- (\S+) \(masked by:.*keyword/mi) { print "Unmasking ${1} in package.keywords\n"; print KEYWORDS "=${1}\n"; return 1; } if(m/^!!! masked or don't exist:\n(\S+)/mi) { while(emerge($1) != 0){} return 1; } return 0;} open(UNMASK, ">>/etc/portage/package.unmask");open(KEYWORDS, ">>/etc/portage/package.keywords");our $package = $ARGV[0];$package =~ s/"/\\"/g;while(emerge($package) != 0){}print "Done\n";close(UNMASK);close(KEYWORDS);

    使用:

    unmask ">media-video/mplayer-1.0_rc1"

    2009-2011© 编译点滴 Suffusion theme by Sayontan Sinha

    无觅相关文章插件,快速提升流量