bashで配列のエクスポートができない@bash 3.2

bashにおいて、サブシェル(呼び出し先の別のシェル)内で呼び出し元の変数を参照しようとする場合、export または declareに-xオプションを使用する必要がありますが、配列変数も同様にexportしても参照できません。

例えば以下の2つのシェルを書きます。

hoge.sh内容

#!/bin/bash
declare -a -x HOGE=("hoge1" "hoge2")    # 配列変数
declare -x FOO="foo"                    # 通常の変数
./foo.sh

foo.sh内容

#!/bin/bash

echo "HOGE="$HOGE
echo "FOO="$FOO

実行すると、下記のように配列の内容を表示できません。

# ./hoge.sh
HOGE=
FOO=foo

これは単純にbashが配列のexportをサポートしてないからのようです。なので、どうしても配列を”source”コマンドまたは”.” コマンドで実行してあげる必要があります。

hoge.sh内容(source版)

#!/bin/bash
declare -a -x HOGE=("hoge1" "hoge2")
declare -x FOO="foo"
source ./foo.sh

実行すると、下記のようにHOGEの内容が表示されます。

# ./hoge.sh
HOGE=hoge1
FOO=foo

もちろんsourceや”.”で実行した場合、サブシェルではなく同じシェル上で実行されるので、fool.sh内での変数宣言がhoge.sh内でも見られるようになりますので、変数名のぶつかりに注意する必要があります。


dsniffパッケージ@Debian Etch

最近ブラッディ・マンデイというドラマの主人公がハッキングするシーンを解説するサイトがありますが、私も見ていて”tcpkill”というコマンドを使っていて、恥ずかしながら知らなかったので調べてみました。

Debian Etch ではdsniffというパッケージに入っているので、早速インストール

# apt-get install dsniff

tcpkillをはじめ、 以下のコマンドがインストールされました。

/usr/sbin/webmitm
/usr/sbin/msgsnarf
/usr/sbin/webspy
/usr/sbin/tcpnice
/usr/sbin/sshow
/usr/sbin/filesnarf
/usr/sbin/dnsspoof
/usr/sbin/tcpkill
/usr/sbin/dsniff
/usr/sbin/macof
/usr/sbin/sshmitm
/usr/sbin/arpspoof
/usr/sbin/urlsnarf
/usr/sbin/mailsnarf

結構な数のコマンドが同梱されています。ちなみに、tcpkillは任意のホストにtcpコネクションを閉じる偽パケットを送って、tcp通信を妨害できるようです。

eth0から出て行く21番ポート(FTP)を遮断

# tcpkill -i eth0 port 21

192.168.0.1 とのtcp通信を遮断

# tcpkill host 192.168.0.1

cygwin ckでmanが見れない@cygwin with ck

cygwinをcygwin ck上で使っているのですが、manを見ようとすると以下のようにエラーが出て見れません。

# man man
/usr/bin/groff: can't find `DESC' file
/usr/bin/groff:fatal error: invalid device `nippon'

原因はcygwinに入っているgroffが日本語に対応していないことです。ネットを少し調べてみると、どこかからソースをダウンロードしてきて日本語用にコンパイルすれば対応できるようですが、面倒なので、環境変数LANG=Cにすれば英語で見れるだろうと実行してみました。

# LANG=C man man

ところが、manは見れるようになったのですが、manの内容が日本語になっていて、化けています。これは環境変数LC_ALLにja_JP.Shift_JISが設定されているのが原因のようです。

# env | grep LC
LC_ALL=ja_JP.Shift_JIS

とりあえず英語でmanが見れればよかったので、~/.bashrcのaliasで以下のようにして回避しました。

# vi ~/.bashrc
alias man='LC_ALL="" man'   ←追記する

# source ~/.bashrc

TracのDBのスキーマとチケットレポート作成 @ Trac 0.10.3 on Debian Etch

Tracのチケット のレポートを作成するには、TracのDBのスキーマをある程度知っておかないと書けないので、スキーマの一覧を出力しました。

CREATE TABLE attachment (
    type text,
    id text,
    filename text,
    size integer,
    time integer,
    description text,
    author text,
    ipnr text,
    UNIQUE (type,id,filename)
);
CREATE TABLE auth_cookie (
    cookie text,
    name text,
    ipnr text,
    time integer,
    UNIQUE (cookie,ipnr,name)
);
CREATE TABLE component (
    name text PRIMARY KEY,
    owner text,
    description text
);
CREATE TABLE enum (
    type text,
    name text,
    value text,
    UNIQUE (type,name)
);
CREATE TABLE milestone (
    name text PRIMARY KEY,
    due integer,
    completed integer,
    description text
);
CREATE TABLE node_change (
    rev text,
    path text,
    node_type text,
    change_type text,
    base_path text,
    base_rev text,
    UNIQUE (rev,path,change_type)
);
CREATE TABLE permission (
    username text,
    action text,
    UNIQUE (username,action)
);
CREATE TABLE report (
    id integer PRIMARY KEY,
    author text,
    title text,
    query text,
    description text
);
CREATE TABLE revision (
    rev text PRIMARY KEY,
    time integer,
    author text,
    message text
);
CREATE TABLE session (
    sid text,
    authenticated integer,
    last_visit integer,
    UNIQUE (sid,authenticated)
);
CREATE TABLE session_attribute (
    sid text,
    authenticated integer,
    name text,
    value text,
    UNIQUE (sid,authenticated,name)
);
CREATE TABLE system (
    name text PRIMARY KEY,
    value text
);
CREATE TABLE ticket (
    id integer PRIMARY KEY,
    type text,
    time integer,
    changetime integer,
    component text,
    severity text,
    priority text,
    owner text,
    reporter text,
    cc text,
    version text,
    milestone text,
    status text,
    resolution text,
    summary text,
    description text,
    keywords text
);
CREATE TABLE ticket_change (
    ticket integer,
    time integer,
    author text,
    field text,
    oldvalue text,
    newvalue text,
    UNIQUE (ticket,time,field)
);
CREATE TABLE ticket_custom (
    ticket integer,
    name text,
    value text,
    UNIQUE (ticket,name)
);
CREATE TABLE version (
    name text PRIMARY KEY,
    time integer,
    description text
);
CREATE TABLE wiki (
    name text,
    version integer,
    time integer,
    author text,
    ipnr text,
    text text,
    comment text,
    readonly integer,
    UNIQUE (name,version)
);
CREATE INDEX node_change_rev_idx ON node_change (rev);
CREATE INDEX revision_time_idx ON revision (time);
CREATE INDEX session_authenticated_idx ON session (authenticated);
CREATE INDEX session_last_visit_idx ON session (last_visit);
CREATE INDEX ticket_change_ticket_idx ON ticket_change (ticket);
CREATE INDEX ticket_change_time_idx ON ticket_change (time);
CREATE INDEX ticket_status_idx ON ticket (status);
CREATE INDEX ticket_time_idx ON ticket (time);
CREATE INDEX wiki_time_idx ON wiki (time);

チケットレポートで主に使うテーブルはもちろん”ticket”です。各カラムは変数名を見るとほぼわかると思いますのでここには書きません。

CREATE TABLE ticket (
    id integer PRIMARY KEY,
    type text,
    time integer,
    changetime integer,
    component text,
    severity text,
    priority text,
    owner text,
    reporter text,
    cc text,
    version text,
    milestone text,
    status text,
    resolution text,
    summary text,
    description text,
    keywords text
);

その他に使うテーブルとしては、”ticket_change”です。これはチケットの更新履歴や追加コメントなどが格納されます。このあたりはチケット周りのテーブル構成のサイトが少し解説しているので参考にしてみてください。

CREATE TABLE ticket_change (
    ticket integer,
    time integer,
    author text,
    field text,
    oldvalue text,
    newvalue text,
    UNIQUE (ticket,time,field)
);

ticketには対象となるチケットのチケットIDが入ります。fieldは更新履歴の種類が入ります。例えば、コメントの追加の場合は”comment”が入りますし、ステータスの変更ならば”status”が入ります。よって、レポートにコメント履歴も出力させたい場合は、以下のようにして出力できます。ここではコンポーネントがcomponent1でバージョンが1.0のチケットとその履歴を出力しています。太字の部分は環境に依存するので、自分の環境で定義されているものに変更します。

SELECT
  t.id,
  t.type,
  t.component,
  t.version,
  t.reporter,
  c.author,
  t.status,
  t.summary,
  t.description,
  c.newvalue
FROM ticket t left join ticket_change c
WHERE t.id = c.ticket AND c.field = "comment" AND
   t.component = “component1″ AND
   t.version = “1.0″
ORDER BY t.id

ちなみにレポートではTrac固有の変数$USERを使うこともできます。

$USER アクセスしているユーザ名

== 追記 2008/12/16 ==

上記のSQLだとnewvalueが空の行が大量に出力されてしまうため、副問い合わせを使ってフィルタリングをかけてみました。さらにidとコメントの順で並び替えるようにしました。以下が改良版です。

SELECT
  t.id,
  c.time,
  t.type,
  t.component,
  t.version,
  t.reporter,
  t.status,
  t.summary,
  t.description,
  c.author,
  c.newvalue
FROM ticket t left join (SELECT * FROM ticket_change WHERE newvalue != '') c
WHERE t.id = c.ticket AND c.field = "comment" AND
   t.component = “component1″ AND
   t.version = “1.0″
ORDER BY t.id, c.time

== 追記 2008/12/18 ==

発行されたばかりで、一度も変更のないチケットは上記だと表示されないので、さらに改良。UNION ALLを使って、発行されたばかりのチケット一覧をマージしています。

SELECT
  t.id as id,
  c.time as time,
  t.type,
  t.component,
  t.version,
  t.reporter,
  t.status,
  t.resolution,
  t.summary,
  t.description,
  c.author,
  c.newvalue
FROM ticket t left join (SELECT * FROM ticket_change WHERE newvalue != '') c
WHERE t.id = c.ticket AND c.field = "comment" AND
   t.component = “component1″ AND
   t.version = “1.0″
UNION ALL
SELECT
  t.id as id,
  t.time as time,
  t.type,
  t.component,
  t.version,
  t.reporter,
  t.status,
  t.resolution,
  t.summary,
  t.description,
  ”,
  ”
FROM ticket t
WHERE t.time = t.changetime AND
   t.component = “component1″ AND
   t.version = “1.0″
ORDER by id, time

携帯動画変換君がqt3gppflatten.exeでエラー

なぜか最近携帯用の着うたを携帯動画変換君で3gpに変換しようとすると、qt3gppflatten.exeでエラーになってしまいます。どうもQuickTimeをアップデートしたのが原因らしく、7.2にダウングレードすると動きました。