Способы лечения невнимательности

Если вдруг вы сделали так
sudo rm /etc/portage/package.keywords/using
а потом немного подумав ещё и так
sudo rm /etc/portage/package.use/using
то вам наверняка нужен отдых ;).
Спустя какое-то время приходит осознание что надо эти пару файлов как то вернуть, а ни бэкапов ни возможности восстановить файлы нет.
Частично можно решить проблему следующими командами
sudo sh -c "eix --installed-unstable --only-names >> /etc/portage/package.keywords/repair"
sudo sh -c "qlist -IU | grep -E '\(' | sed 's/(//;s/)//' >> /etc/portage/package.use/repair"
Конечно это не вернёт утраченные файлы в первозданном виде, но почти заставит пакетный менеджер работать также как и раньше ;)
з.ы.: комментарии с исправлениями и улучшениями приветствуются, пост написан в аффектном состоянии и автор не несёт ответственности за работоспособность вашей системы после выполнения вышеуказанных действий ;)

egencache

При использовании sqlite для хранения кэша portage возникают некоторые смежные проблемы, которые хорошо расписаны в man и на форумах, но поскольку многие их не читают вообще решил прояснить кое какие моменты в своём блоге.
Ссылки на вики про настройку всем известны, но приведу их для конкретизации источника информации.
http://en.gentoo-wiki.com/wiki/Portage_SQLite_Cache
http://ru.gentoo-wiki.com/wiki/%D0%A0%D0%B0%D0%B7%D0%BC%D0%B5%D1%89%D0%B5%D0%BD%D0%B8%D0%B5_%D0%BA%D0%B5%D1%88%D0%B0_Portage_%D0%B2_SQLite

Почти не отличимые оригинал (чуть более новый) и перевод. Отличается лишь одное значение
OVERLAY_CACHE_METHOD=...
Указание что что-то неведомым образом там не работает :-P
Такие вики конечно повергают в шок, ну да ладно идём читать man eix или форумы о генту и выясняем что надо немного поправить конфиги и всего-то

/etc/eix-sync.conf

*
@egencache --repo=wavilen --update

естественно egencache надо вызывать для каждого оверлея в котором нет метаданных (а таких большинство), можно вызывать руками, но разумнее прописать в конфиг. Если вдруг требуется отдельно перегенерировать метаданные для всех оверлеев (бывает запинается из-за ошибок ebuild'описателей)можно просто отпарсить выбрав нужное из конфига и создать shell скрипт

sudo sh -c "cat /etc/eix-sync.conf | sed '/\*/d;s/^\@//g' > /etc/egencache.sh"

Примечание: предлагаемый скрипт явно сыроват, необходимо предусмотреть логирование...

Конечно самом по себе использование sqlite кэша приносит малозаметный эффект, но если объединить с монтированием дерева portage, оверлеев и кэша к ним по NetworkFSv4, то поводов для настройки становится больше. Кстати на счёт кэша я возможно погорячился, но пока более правильного метода не потянул...

Продолжение следует...

Rigelmcr

Достаточно давно срисовал ebuild, но всё не доходили руки задействовать.
sudo tcpdump -i eth0 igmp
смотрим где "хвосты"

22:05:08.517506 IP 10.222.32.1 > ALL-SYSTEMS.MCAST.NET: igmp query v2
22:05:13.031940 IP ТУТ.БЫЛ.МОЙ.АЙПИ > 239.255.255.250: igmp v2 report 239.255.255.250
рисуем конфиг (к примеру такой для машины с тремя физическими сетевыми интерфейсами)
sudo vim /etc/rigelmcr.conf

default_mode downstream
phyint eth0 upstream
        access allow dst 239.192.152.143/24
                allow src 10.0.0.0/8
                deny dst 0.0.0.0/0

phyint br0 downstream

phyint eth1 disabled
phyint eth2 disabled

;) IPTV в линуксе быть!

portage и python 2.7

Случилось так что я поменял USE флаги для python (добавил sqlite), после чего 2.6 и 3.1 ветки благополучно были пересобраны, а emerge и ebuild больше не работали, привожу лог последнего
Traceback (most recent call last):
  File "/usr/bin/ebuild", line 138, in 
    ebuild_portdir not in portage.portdb.porttrees:
  File "/usr/lib64/portage/pym/portage/proxy/objectproxy.py", line 22, in __getattribute__
    result = object.__getattribute__(self, '_get_target')()
  File "/usr/lib64/portage/pym/portage/__init__.py", line 592, in _get_target
    return _get_legacy_global(name)
  File "/usr/lib64/portage/pym/portage/_legacy_globals.py", line 14, in _get_legacy_global
    portage.portdb = portage.db[portage.root]["porttree"].dbapi
  File "/usr/lib64/portage/pym/portage/util/__init__.py", line 1304, in __getitem__
    result = lazy_item.func(*pargs, **kwargs)
  File "/usr/lib64/portage/pym/portage/dbapi/porttree.py", line 1019, in __init__
    self.dbapi = portdbapi(mysettings=settings)
  File "/usr/lib64/portage/pym/portage/dbapi/porttree.py", line 152, in __init__
    self.auxdbmodule = self.settings.load_best_module("portdbapi.auxdbmodule")
  File "/usr/lib64/portage/pym/portage/package/ebuild/config.py", line 844, in load_best_module
    mod = load_mod(best_mod)
  File "/usr/lib64/portage/pym/portage/__init__.py", line 402, in load_mod
    mod = __import__(modname)
  File "/usr/lib64/portage/pym/portage/cache/sqlite.py", line 14, in 
    from pysqlite2 import dbapi2 as db_module
ImportError: No module named pysqlite2
А случилось так потому что я не так давно размаскировал dev-lang/python:2.7, очевидно что его надо было поставить как-то, было найдено простейшее решение - собрать его на другой машине и распаковать в корень.
На удалённой машине надо было закомментировать оптимизации под процессор и выполнить
sudo ACCEPT_KEYWORDS="~amd64" emerge -avB1 dev-lang/python:2.7
На локальной
sftp user@host:/usr/portage/packages/dev-lang/python-2.7.1.tbz2
(пример для ssh)

IPTV video player

После сравнительно долгого мучения сначала с smplayer, потом с vlc для просмотра IPTV я открыл для себя Tano ( нашёл я его тут ).
Конечно меня ожидали некоторые трудности - первая из которых никто не написал досих пор ebuild'ов для сборки оной программы. Написал, забирать напомню в моём оверлее
sudo layman -a wavilen

Вторая сложность - пришлось ручками поправить плейлист предоставляемый провайдером, чтобы tano его "скушал", благо примеры устанавливаются вместе с плеером
equery f tano | grep m3u 

Конфиг zsh (FreeBSD)

Комментарии и адаптация к linux скорее всего будут написаны позже.
Просто мне надо размножить основные принципы, решил выложить здесь.

setopt INC_APPEND_HISTORY SHARE_HISTORY HIST_IGNORE_DUPS HIST_IGNORE_ALL_DUPS HIST_REDUCE_BLANKS HIST_IGNORE_SPACE HIST_NO_STORE HIST_VERIFY
setopt EXTENDED_HISTORY HIST_SAVE_NO_DUPS HIST_EXPIRE_DUPS_FIRST HIST_FIND_NO_DUPS APPEND_HISTORY
setopt CORRECT MENUCOMPLETE ALL_EXPORT
setopt   notify globdots correct pushdtohome cdablevars autolist
setopt   correctall autocd recexact longlistjobs
setopt   autoresume histignoredups pushdsilent 
setopt   autopushd pushdminus extendedglob rcquotes mailwarning
setopt  No_Beep
unsetopt bgnice autoparamslash

HISTFILE=$HOME/.zhistory
HISTSIZE=10000
SAVEHIST=10000
autoload -U predict-on
zle -N predict-on
zle -N predict-off
bindkey -M emacs "^X^Z" predict-on
bindkey -M emacs "^Z" predict-off

alias ls='ls -G'
alias ll='ls -lh'
alias la='ls -a'
alias l='ls'
export GREP_OPTIONS='--color=auto'
export GREP_COLOR='1;33'



autoload -U compinit
compinit
bindkey -v
bindkey "`echotc kI`" yank # Insert
bindkey "`echotc kD`" delete-char # Delete
bindkey "`echotc kP`" up-line-or-history # Page Up
bindkey "`echotc kN`" down-line-or-history # Page Down
bindkey "`echotc ku`" up-line-or-search ## up arrow for back-history-search
bindkey "`echotc kd`" down-line-or-search ## down arrow for fwd-history-search
bindkey "`echotc kh`" beginning-of-line # Home
bindkey "`echotc @7`" end-of-line # End



zstyle ':completion::complete:*' use-cache on
zstyle ':completion::complete:*' cache-path ~/.zsh/cache/$HOST
zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS}
zstyle ':completion:*' list-prompt '%SAt %p: Hit TAB for more, or the character to insert%s'
zstyle ':completion:*' menu select=1 _complete _ignored _approximate
zstyle -e ':completion:*:approximate:*' max-errors \
    'reply=( $(( ($#PREFIX+$#SUFFIX)/2 )) numeric )'
zstyle ':completion:*' select-prompt '%SScrolling active: current selection at %p%s'
zstyle ':completion:*::::' completer _expand _complete _ignored _approximate
zstyle -e ':completion:*:approximate:*' max-errors \
    'reply=( $(( ($#PREFIX+$#SUFFIX)/2 )) numeric )'
zstyle ':completion:*:expand:*' tag-order all-expansions
zstyle ':completion:*' verbose yes
zstyle ':completion:*:descriptions' format '%B%d%b'
zstyle ':completion:*:messages' format '%d'
zstyle ':completion:*:warnings' format 'No matches for: %d'
zstyle ':completion:*:corrections' format '%B%d (errors: %e)%b'
zstyle ':completion:*' group-name ''
zstyle ':completion:*' matcher-list 'm:{a-z}={A-Z}'
zstyle ':completion:*:*:-subscript-:*' tag-order indexes parameters
zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#)*=0=01;31'
zstyle ':completion:*:*:kill:*:processes' command 'ps --forest -A -o pid,user,cmd'
zstyle ':completion:*:processes-names' command 'ps axho command' 

[[ -f /usr/local/bin/grc ]] && {
  alias ping="grc --colour=auto ping"
  alias traceroute="grc --colour=auto traceroute"
  alias make="grc --colour=auto make"
  alias diff="grc --colour=auto diff"
  alias cvs="grc --colour=auto cvs"
  alias netstat="grc --colour=auto netstat"
}


extract () {
    if [ -f $1 ] ; then
        case $1 in
            *.tar.bz2)   tar xvjf $1        ;;
            *.tar.gz)    tar xvzf $1     ;;
            *.bz2)       bunzip2 $1       ;;
            *.rar)       unrar x $1     ;;
            *.gz)        gunzip $1     ;;
            *.tar)       tar xvf $1        ;;
            *.tbz2)      tar xvjf $1      ;;
            *.tgz)       tar xvzf $1       ;;
            *.zip)       unzip $1     ;;
            *.Z)         uncompress $1  ;;
            *.7z)        7z x $1    ;;
            *)           echo "'$1' cannot be extracted via >extract<" ;;
        esac
    else
        echo "'$1' is not a valid file"
    fi
}




autoload -U colors

autoload colors zsh/terminfo
if [[ "$terminfo[colors]" -ge 8 ]]; then
   colors
fi
   for color in RED GREEN YELLOW BLUE MAGENTA CYAN WHITE; do
   eval PR_$color='%{$terminfo[bold]$fg[${(L)color}]%}'
   eval PR_LIGHT_$color='%{$fg[${(L)color}]%}'
   (( count = $count + 1 ))
done
   PR_NO_COLOUR="%{$terminfo[sgr0]%}"

local blue_op=""$PR_BLUE"["$PR_NO_COLOUR""
local blue_cp=""$PR_BLUE"]"$PR_NO_COLOUR""
local blue_zd=""$PR_BLUE"╭─"$PR_NO_COLOUR""
local blue_zu=""$PR_BLUE"╰─"$PR_NO_COLOUR""
local path_p="${blue_op}$PR_MAGENTA%/$PR_NO_COLOUR${blue_cp}%b"
local user_host="${blue_op}%B$PR_GREEN%n@%m$PR_NO_COLOUR${blue_cp}"
PROMPT="${blue_zd}${user_host}$PR_BLUE─$PR_NO_COLOUR${path_p}
${blue_zu}$PR_BLUE%#$PR_NO_COLOUR "
RPROMPT="%B%*%b"


export LANG=ru_RU.UTF-8
export LC_ALL=ru_RU.UTF-8
export EDITOR=vim
export PAGER=less
export PORTSEARCH_OUTFIELDS=name,path,info,www
echo "List all tmux sessions managed by the server:"
tmux ls

VA-API plugins for GStreamer

В поисках лучшей жизни решил испытать, лучшей жизни не получилось - определённые неровности в работе всё же присутствуют, но раз работа проделана - надо описать ;)
Результат - ebuild - в моём оверлее:
sudo layman -a wavilen
После установки можно проверить действительно ли оно зарегистрировалось в системе:
# gst-inspect-0.10 | grep vaapi
vaapisink:  vaapisink: VA-API sink
vaapidecode:  vaapidecode: VA-API decoder
vaapiconvert:  vaapiconvert: VA-API colorspace converter

Ссылки на тему:
http://www.freedesktop.org/wiki/Software/vaapi
http://www.splitted-desktop.com/~gbeauchesne/gstreamer-vaapi/
https://bbs.archlinux.org/viewtopic.php?pid=830180
http://gstreamer-devel.966125.n4.nabble.com/VA-API-support-td2165423.html