= WeeChat ユーザーズガイド :author: Sébastien Helleu :email: flashcode@flashtux.org :toc2: :toclevels: 3 :toc-title: 目次 :max-width: 100% 翻訳者: * Ryuunosuke Ayanokouzi , 2012-2014 このマニュアルは WeeChat チャットクライアントについての文書で、これは WeeChat の一部です。 この文書の最新版は以下のページにあります: https://weechat.org/doc [[introduction]] == イントロダクション WeeChat (Wee Enhanced Environment for Chat) はフリーのチャットクライアントです。 高速で軽量、多くのオペレーティングシステムで動くように設計されています。 [[features]] === 特徴 主な特徴: * マルチプロトコル: IRC 及び Jabber (jabber.py スクリプトや bitlbee/minbif が必要) * 複数のサーバへの接続 (SSL、IPv6、プロキシをサポート) * コンパクト、高速、軽量 * プラグインとスクリプトでカスタマイズや拡張が可能 * IRC の RFC に準拠 http://tools.ietf.org/html/rfc1459[1459]、 http://tools.ietf.org/html/rfc2810[2810]、 http://tools.ietf.org/html/rfc2811[2811]、 http://tools.ietf.org/html/rfc2812[2812]、 http://tools.ietf.org/html/rfc2813[2813]。 * リモートインターフェイス用の IRC プロキシとリレー * マルチプラットフォーム (GNU/Linux、*BSD、MacOS X、Windows 等) * 完全な GPL、フリーソフトウェア WeeChat のホームページ: https://weechat.org/ [[prerequisites]] === 事前に必要なもの WeeChat をインストールするには、以下のものが必要です: * GNU/Linux が稼動しているシステム (ソースパッケージを使う場合は、 コンパイラツールも必要)、又は互換 OS * 'root' 特権 (WeeChat をシステムディレクトリにインストールする場合) * 一部のライブラリ (<>を参照)。 [[install]] == インストール方法 [[binary_packages]] === バイナリパッケージ 多くのディストリビューションではバイナリパッケージが利用できます。例えば: * Debian (または Debian 互換ディストリビューション): `apt-get install weechat-curses` * Mandriva/RedHat (または RPM 互換ディストリビューション): `rpm -i /path/to/weechat-x.y.z-1.i386.rpm` * Gentoo: `emerge weechat` * Arch Linux: `pacman -S weechat` * Fedora Core: `yum install weechat` * Sourcemage: `cast weechat` * Cygwin (Windows): setup.exe で WeeChat パッケージを選択してください 例えば weechat-plugins 等の追加パッケージを使うとより便利になるかもしれません。 その他のディストリビューションでは、 インストール説明マニュアルを参照してください。 [[source_package]] === ソースパッケージ WeeChat は cmake または autotools を使ってコンパイルできます (cmake を使うことが推奨されています)。 [NOTE] OS X では、http://brew.sh/[Homebrew] を使ってください: `brew install weechat --with-python --with-perl` (ヘルプを見るには: `brew info weechat`)。 [[dependencies]] ==== 依存関係 以下の表は WeeChat のコンパイルに必須または任意で必要なパッケージのリストです。 [width="100%",cols="5,^3,^3,.^13",options="header"] |=== | パッケージ ^(1)^ | バージョン | 要件 | 機能 | cmake | | *必須* | ビルド (autotools でも可能ですが、cmake を推奨します) | pkg-config | | *必須* | インストール済みライブラリを検出 | libncursesw5-dev ^(2)^ | | *必須* | ncurses インターフェイス | libcurl4-gnutls-dev | | *必須* | URL 転送 | zlib1g-dev | | *必須* | relay プラグインでパケットを圧縮 (weechat プロトコル)、スクリプトプラグイン | libgcrypt20-dev | | *必須* | 保護データ、IRC SASL 認証 (DH-BLOWFISH/DH-AES)、スクリプトプラグイン | libgnutls28-dev | ≥ 2.2.0 ^(3)^ | | IRC サーバへの SSL 接続、IRC SASL 認証 (ECDSA-NIST256P-CHALLENGE) | gettext | | | 国際化 (メッセージの翻訳; ベース言語は英語です) | ca-certificates | | | SSL 接続に必要な証明書、relay プラグインで SSL サポート | libaspell-dev または libenchant-dev | | | aspell プラグイン | python-dev | ≥ 2.5 ^(4)^ | | python プラグイン | libperl-dev | | | perl プラグイン | ruby2.1-dev | ≥ 1.8 | | ruby プラグイン | liblua5.2-dev | | | lua プラグイン | tcl-dev | ≥ 8.5 | | tcl プラグイン | guile-2.0-dev | ≥ 2.0 | | guile (scheme) プラグイン | libv8-dev | ≤ 3.24.3 | | javascript プラグイン | asciidoc | ≥ 8.5.0 | | man ページと文書のビルド | source-highlight | | | 文書中のソースに対するシンタックスハイライト | xsltproc, docbook-xml, docbook-xsl | | | man ページのビルド | libcpputest-dev | ≥ 3.4 | | テストの実行 | C++ コンパイラ | | | テスト実行、javascript プラグイン |=== [NOTE] ^(1)^ Debian GNU/Linux ディストリビューションにおけるパッケージ名です。 他のディストリビューションではバージョンとパッケージ名が異なるかもしれません。 + ^(2)^ WeeChat は libncurses5-dev でもコンパイル可能ですが、これは推奨*されません* (ワイドキャラクタの表示にバグを生じるでしょう)。 + ^(3)^ IRC SASL 認証で ECDSA-NIST256P-CHALLENGE を使うには、Gnutls バージョン 3.0.21 以上が必要です。 + ^(4)^ Python はバージョン 2.7 をお勧めします (全てのスクリプトはバージョン 2.7 で正しく動きますが、バージョン 2.6 以下または 3.0 以上では正しく動きません)。 [[compile_with_cmake]] ==== cmake によるコンパイル * システムディレクトリにインストールする場合 ('root' 特権が必要です): ---- $ mkdir build $ cd build $ cmake .. $ make % make install (as root) ---- * 任意のディレクトリにインストールする場合: ---- $ mkdir build $ cd build $ cmake .. -DCMAKE_INSTALL_PREFIX=/path/to/directory $ make $ make install ---- cmake に対するオプションを指定するには、以下のフォーマットを使ってください: "-DOPTION=VALUE". よく利用されるオプションのリスト: [width="100%",cols="2m,2,5m,12",options="header"] |=== | オプション | 値 | デフォルト値 | 説明 | CMAKE_BUILD_TYPE | `Debug`, `Release`, `RelWithDebInfo`, `MinSizeRel` | | ビルド形式: WeeChat の開発版を使っている場合は `Debug` (または `RelWithDebInfo`) を推奨します。 | CMAKE_INSTALL_PREFIX | directory | /usr/local | WeeChat をインストールするディレクトリ。 | WEECHAT_HOME | directory | ~/.weechat | WeeChat 実行時のホームディレクトリ。 | CA_FILE | file | /etc/ssl/certs/ca-certificates.crt | 認証局を含むファイル。これは <> オプションのデフォルト値です。 | ENABLE_ALIAS | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_ASPELL | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_CHARSET | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_MAN | `ON`, `OFF` | OFF | man ページのコンパイル。 | ENABLE_DOC | `ON`, `OFF` | OFF | 文書のコンパイル (コンパイルには時間がかかります。文書を含めたバイナリパッケージをビルドする場合、オンラインで文書を見ることができない場合だけに推奨します)。 | ENABLE_ENCHANT | `ON`, `OFF` | OFF | Enchant と含めた <>のコンパイル。 | ENABLE_EXEC | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_FIFO | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_GNUTLS | `ON`, `OFF` | ON | Gnutls の有効化 (SSL 用)。 | ENABLE_GUILE | `ON`, `OFF` | ON | <> (Scheme) のコンパイル。 | ENABLE_IRC | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_JAVASCRIPT | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_LARGEFILE | `ON`, `OFF` | ON | 巨大ファイルのサポート。 | ENABLE_LOGGER | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_LUA | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_NCURSES | `ON`, `OFF` | ON | Ncurses インターフェイスのコンパイル。 | ENABLE_NLS | `ON`, `OFF` | ON | NLS の有効化 (翻訳). | ENABLE_PERL | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_PYTHON | `ON`, `OFF` | ON | <>のコンパイル。 | ENABLE_PYTHON3 | `ON`, `OFF` | OFF | Python 3 を使った <>のコンパイル (多くのスクリプトは Python 3 と互換性がないため*非推奨* です)。 | ENABLE_RELAY | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_RUBY | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_SCRIPT | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_SCRIPTS | `ON`, `OFF` | ON | すべての<> (Python、Perl、Ruby、Lua、Tcl、Guile、Javascript) のコンパイル | ENABLE_TCL | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_TRIGGER | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_XFER | `ON`, `OFF` | ON | <>のコンパイル | ENABLE_TESTS | `ON`, `OFF` | OFF | コンパイルテスト。 |=== その他のオプションは以下のコマンドで確認してください: ---- $ cmake -LA ---- Curses インターフェイスを使う場合は以下のコマンドを使ってください: ---- $ ccmake .. ---- [[compile_with_autotools]] ==== autotools によるコンパイル [WARNING] cmake 以外を用いた WeeChat のビルドは公式にサポートされません。cmake を利用できない場合のみ autotools を使ってください。 + autotools を用いてビルドする場合、cmake よりも多くの依存パッケージとより長い時間が必要です。 * システムディレクトリにインストールする場合 ('root' 特権が必要です): ---- $ ./autogen.sh $ mkdir build $ cd build $ ../configure $ make % make install (as root) ---- * 任意のディレクトリにインストールする場合: ---- $ ./autogen.sh $ mkdir build $ cd build $ ../configure --prefix=/path/to/directory $ make $ make install ---- 'configure' スクリプトに対してオプションを指定することができます、オプションを表示するには以下のコマンドを使ってください: ---- $ ./configure --help ---- [[git_sources]] === Git ソース 警告: git ソースを用いる方法は上級者向けです。コンパイルに失敗したり、 不安定な可能性があります。警告しましたよ! git ソースを入手するには、以下のコマンドを使ってください: ---- $ git clone https://github.com/weechat/weechat.git ---- その後は、ソースパッケージの説明に従ってください (<>を参照)。 [[report_crashes]] === クラッシュレポート WeeChat がクラッシュした場合、または WeeChat をクラッシュさせる操作を報告する場合、以下の手順に従ってください: * デバッグを有効化してコンパイル (またはデバック情報を含んだバイナリパッケージをインストール) * システムの 'core' ファイルを有効化 * gdb のインストール [[debug_info]] ==== デバッグ情報 cmake でコンパイルする場合: ---- $ cmake .. -DCMAKE_BUILD_TYPE=Debug ---- autotools でコンパイルする場合は、デバックはデフォルトで有効化されています(`--with-debug=1`)。 バイナリパッケージをインストールする場合は、'weechat-dbg' パッケージをインストールしてください。 [[core_files]] ==== Core ファイル 'core' ファイルを有効化するには、<> オプションを使ってください: ---- /set weechat.startup.sys_rlimit "core:-1" ---- WeeChat バージョン 0.3.8 以下または WeeChat の実行前に core ファイルを有効化したい場合には、`ulimit` コマンドを使ってください。 Linux で 'bash' シェルを使っている場合、以下の内容を `~/.bashrc` に追加してください: ---- ulimit -c unlimited ---- サイズを指定する場合は: ---- ulimit -c 200000 ---- [[gdb_backtrace]] ==== gdb でバックトレースを得る WeeChat がクラッシュすると、'core' または 'core.12345' ファイルが作られます ('12345' はプロセス番号です)。 このファイルは WeeChat を起動したディレクトリに作られます (これは WeeChat がインストールされているディレクトリでは*ありません*!)。 例えば、'weechat' が '/usr/bin/' にインストールされ、'core' ファイルが '/home/xxx/' にある場合、以下のコマンドで gdb を起動してください: ---- gdb /usr/bin/weechat /home/xxx/core ---- gdb の中で `bt full` コマンドを実行するとバックトレースが表示されます。 以下のような出力が得られるはずです: ---- (gdb) set logging file /tmp/crash.txt (gdb) set logging on Copying output to /tmp/crash.txt. (gdb) bt full #0 0x00007f9dfb04a465 in raise () from /lib/libc.so.6 #1 0x00007f9dfb04b8e6 in abort () from /lib/libc.so.6 #2 0x0000000000437f66 in weechat_shutdown (return_code=1, crash=1) at /some_path/src/core/weechat.c:351 #3 #4 0x000000000044cb24 in hook_process_timer_cb (arg_hook_process=0x254eb90, remaining_calls=) at /some_path/src/core/wee-hook.c:1364 hook_process = 0x254eb90 status = #5 0x000000000044cc7d in hook_timer_exec () at /some_path/src/core/wee-hook.c:1025 tv_time = {tv_sec = 1272693881, tv_usec = 212665} ptr_hook = 0x2811f40 next_hook = 0x0 #6 0x000000000041b5b0 in gui_main_loop () at /some_path/src/gui/curses/gui-curses-main.c:319 hook_fd_keyboard = 0x173b600 tv_timeout = {tv_sec = 0, tv_usec = 0} read_fds = {fds_bits = {0 }} write_fds = {fds_bits = {0 }} except_fds = {fds_bits = {0 }} max_fd = ---- このバックトレースを開発者に報告し、 クラッシュを引き起こした動作を伝えてください。 お手伝いに感謝します! [[debug_running_weechat]] ==== 起動した WeeChat のデバッグ 起動している WeeChat をデバッグするには (例えば WeeChat がフリーズしているような場合)、gdb の引数にプロセス番号を与えて起動します ('12345' は weechat プロセスの PID に変更してください): ---- gdb /usr/bin/weechat 12345 ---- クラッシュが起きた場合と同様に、`bt full` コマンドを使ってください: ---- (gdb) bt full ---- [[usage]] == 使い方 [[running_weechat]] === WeeChat の起動 コマンドライン引数: include::cmdline_options.ja.asciidoc[] WeeChat を起動させるには、以下コマンドを実行: ---- $ weechat ---- 初めて WeeChat を起動する場合、デフォルトのオプションで設定ファイルが作成されます。 このデフォルト設定ファイルは '~/.weechat/weechat.conf' です。 WeeChat を設定するにはこのファイルを編集するか、 WeeChat 内で `/set` コマンドにパラメータを付けて設定します (<>を参照)。 [[screen_layout]] === スクリーンレイアウト WeeChat を起動したターミナルの例: .... ▼ "title" バー ┌───────────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:52:27 --> | Flashy (flashcode@weechat.org) has joined #test │@Flashy│ │12:52:27 -- | Nicks #test: [@Flashy @joe +weebot peter] │@joe │ │12:52:27 -- | Channel #test: 4 nicks (2 ops, 1 voice, 1 normal) │+weebot│ │12:52:27 -- | Channel created on Tue Jan 27 06:30:17 2009 │peter │ │12:54:15 peter | hey! │ │ │12:55:01 @joe | hello │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [6] [irc/freenode] 3:#test(+n){4}* [H: 4:#abc(2,5), 6] │ │[@Flashy(i)] hi peter!█ │ └───────────────────────────────────────────────────────────────────────────┘ ▲ "status" と "input" バー "nicklist" バー ▲ .... スクリーンは以下のエリアから成ります: * チャットログが表示されるチャットエリア (スクリーンの真ん中)、それぞれの行は: ** 時刻 ** プレフィックス ("|" の前) ** メッセージ ("|" の後) * チャットエリアの周りにあるバー、デフォルトバーは: ** タイトル ('title') バー、チャットエリアの上 ** 状態 ('status') バー、チャットエリアの下 ** 入力 ('input') バー、状態バーの下 ** ニックネームリスト ('nicklist') バー、右端 状態 ('status') バーは以下の初期値を持っています: [width="100%",cols="^3,^4,10",options="header"] |=== | アイテム | 例 | 説明 | time | `[12:55]` | 時刻 | buffer_last_number | `[6]` | リスト中の最後のバッファ番号 | buffer_plugin | `[irc/freenode]` | 現在のバッファのプラグイン (irc プラグインではバッファで利用されている IRC サーバ名を追加できます) | buffer_number | `3` | 現在のバッファの番号 | buffer_name | `#test` | 現在のバッファの名前 | buffer_modes | `+n` | IRC チャンネルモード | buffer_nicklist_count | `{4}` | ニックネームリスト中のニックネームの数 | buffer_zoom | ! | `!` はマージされたバッファがズームされている状態 (ズームされたものだけを表示する状態) を示します、空の場合はすべてのマージされたバッファが表示されていることを示します | buffer_filter | `*` | フィルタ表示: `*` の場合いくつかの行がフィルタされ (隠され) ます、空の場合すべての行が表示されます。 | scroll | `-MORE(50)-` | スクロール表示、最後の行が表示されてから追加された行数を含む。 | lag | `[Lag: 2.5]` | 遅延秒表示 (遅延が短い場合は非表示) | hotlist | `[H: 4:#abc(2,5), 6]` | 変化のあったバッファのリスト (未読メッセージ) (例では、'#abc' に 2 個のハイライトと 5 個の未読メッセージ、6 番目のバッファに 1 個の未読メッセージがあることを意味します。) | completion | `abc(2) def(5)` | 補完候補の単語リスト、各単語に対して適応される補完候補の数を含む。 |=== 入力 ('input') バーは以下の初期値を持っています: [width="100%",cols="^3,^4,10",options="header"] |=== | アイテム | 例 | 説明 | input_prompt | `[@Flashy]` | 入力プロンプト、irc の場合: ニックネームとモード (freenode では "+i" モードは不可視状態を意味します) | away | `(away)` | 離席状態表示 | input_search | `[Search (~ str,msg)]` | 検索インジケータ ("`~`": 大文字小文字を区別しない、"`==`": 大文字小文字を区別する、"`str`": 検索文字列、"`regex`": 検索正規表現、"`msg`": メッセージ部分から検索、"`pre`": プレフィックス部分から検索、"`pre\|msg`": プレフィックス部分とメッセージ部分から検索) | input_paste | `[Paste 7 lines ? [ctrl-Y] Yes [ctrl-N] No]` | 行をペーストする場合にユーザへ行われる質問 | input_text | `hi peter!` | 入力テキスト |=== その他の利用可能なアイテム (デフォルトではバーで使われていない): [width="100%",cols="^3,^4,10",options="header"] |=== | アイテム | 例 | 説明 | aspell_dict | `fr,en` | 現在のバッファにおけるスペリング辞書 | aspell_suggest | `print,prone,prune` | カーソル下の単語に対するスペリング候補 (スペルが間違っている場合) | buffer_count | `10` | 開いているバッファの総数 | buffer_short_name | `#test` | 現在のバッファの短い名前 | irc_channel | `#test` | 現在の IRC チャンネル名 | irc_nick_modes | `@` | 自分のニックネームに対する IRC モード | mouse_status | `M` | マウスの状態 (マウスが無効化されている場合は空文字列) | window_number | `2` | 現在のウィンドウ番号 |=== [[buffers_and_windows]] === バッファとウィンドウ 'バッファ' は番号、名前、表示された行 (とその他の情報) で構成されています。 バッファの例: * コアバッファ (動時にy WeeChat が作成、閉じることはできない) * irc サーバ (サーバからのメッセージを表示) * irc チャンネル * irc プライベート 'window' はバッファを表示するスクリーンエリアのことです。 スクリーンを複数のウィンドウに分割することができます。 それぞれのウィンドウは 1 つのバッファを表示します。バッファは隠したり (ウィンドウに表示しない)、複数のウィンドウに表示することできます。 水平方向分割の例 (`/window splith`): .... ▼ ウィンドウ #2 (バッファ #4) ┌───────────────────────────────────────────────────────────────────────────┐ │Welcome to #abc │ │12:55:12 Max | hi │@Flashy│ │12:55:20 @Flashy | hi Max! │Max │ │12:55:32 Max | how are you? │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [6] [irc/freenode] 4:#abc(+n){2} │ │[@Flashy] │ │───────────────────────────────────────────────────────────────────────────│ │Welcome to #test │ │12:54:15 peter | hey! │@Flashy│ │12:55:01 @joe | hello │@joe │ │ │+weebot│ │ │peter │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [6] [irc/freenode] 3:#test(+n){4} │ │[@Flashy] hi peter!█ │ └───────────────────────────────────────────────────────────────────────────┘ ▲ ウィンドウ #1 (バッファ #3) .... 垂直方向分割の例 (`/window splitv`): .... ┌───────────────────────────────────────────────────────────────────────────┐ │Welcome to #test │Welcome to #abc │ │12:54:15 peter | hey! │@Flashy│12:55:12 Max | hi │@Flashy│ │12:55:01 @joe | hello │@joe │12:55:20 @Flashy | hi Max! │Max │ │ │+weebot│ │ │ │ │peter │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [irc/oftc] 3:#test(+n){4} │[12:55] [irc/oftc] 4:#abc(+n){2} │ │[@Flashy] hi peter!█ │[@Flashy] │ └───────────────────────────────────────────────────────────────────────────┘ ▲ ウィンドウ #1 (バッファ #3) ▲ ウィンドウ #2 (バッファ #4) .... 垂直方向 + 水平方向分割の例: .... ▼ ウィンドウ #3 (バッファ #5) ┌───────────────────────────────────────────────────────────────────────────┐ │Welcome to #test │Welcome to #def │ │12:54:15 peter | hey! │@Flashy│12:55:42 @Flashy | hi │@Flashy│ │12:55:01 @joe | hello │@joe │12:55:56 alex | hi Flashy │alex │ │ │+weebot│ │ │ │ │peter │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [irc/oftc] 5:#def(+n){2} │ │ │ │[@Flashy] │ │ │ │─────────────────────────────────────│ │ │ │Welcome to #abc │ │ │ │12:55:12 Max | hi │@Flashy│ │ │ │12:55:20 @Flashy | hi Max! │Max │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [irc/oftc] 3:#test(+n){4} │[12:55] [irc/oftc] 4:#abc(+n){2} │ │[@Flashy] hi peter!█ │[@Flashy] │ └───────────────────────────────────────────────────────────────────────────┘ ▲ ウィンドウ #1 (バッファ #3) ▲ ウィンドウ #2 (バッファ #4) .... [[bars]] === バー 'バー' とは任意のテキストを含めることができるチャットエリア以外の場所です。 バーオプションは `weechat.bar.name.option` オプションで設定します。ここで `name` はバーの名前、`option` はこのバーのオプション名です。 バーオプションのリスト: [width="100%",cols="2m,2,10",options="header"] |=== | オプション名 | 値 | 説明 | type | `root`、`window` | `root` 型のバーは画面に (全てのウィンドウの外に) 1 回だけ表示されます。デフォルトでは root バーはありませんが、'buffers.pl' スクリプトが作成する 'buffers' バー (バッファのリストを含むサイドバー) が例の 1 つです。 + `window` 型のバーは各ウィンドウに対して表示されます。例えば (`/window splith` や `/window splitv` で) 画面を 1 回分割する場合、それぞれのウィンドウにバーが 1 つ表示されます。4 つのデフォルトバー ('title'、'status'、'input'、'nicklist') は `window` 型のバーです。 | position | `top`、`bottom`、`left`、`right` | バーの位置: チャットエリアの上、下、左、右。 | priority | 0 以上の整数 | バーの表示優先度: 型と位置が同じ複数のバーを画面に表示する順番に利用される。 + バーは画面の端から中心に向かって表示される。高い優先度を持つバーが先に (画面の端に近い側に) 表示される。 + 例: 優先度 1000 の 'input' バーは優先度 500 の 'status' バーよりも先に表示される。 | size | 0 以上の整数 | バーのサイズ: 位置が右/左の場合は列数、位置が上/下の場合は行数。値が `0` の場合は自動 (バーのサイズはバーの内容を基に計算される)。 | size_max | 0 以上の整数 | バーの最大サイズ、`0` = 制限無し (このオプションは `size` = `0` の場合のみ使われる)。 | color_bg | 色 | バーのデフォルトの背景色 | color_fg | 色 | バーのデフォルトのテキスト色 | color_delim | 色 | バーの区切り文字の色 | hidden | `on`、`off` | このオプションが `on` の場合、バーは表示されません。 + 注意: このオプションを変更する代わりに、`/bar` コマンドを使うと便利です。例: `/bar toggle nicklist` (<> コマンドを参照)。 | separator | `on`、`off` | このオプションが `on` の場合、セパレータ (区切り線) がバー同士またはバーとチャットエリアの間に表示されます。 | items | 文字列 | 'items' のリスト (詳細は<>を参照)。 | filling_left_right | `horizontal`、`vertical`、`columns_horizontal`、`columns_vertical` | 位置が `left` または `right` のバーに対するフィリングタイプ (詳細は<>を参照)。 | filling_top_bottom | `horizontal`、`vertical`、`columns_horizontal`、`columns_vertical` | 位置が `top` または `bottom` のバーに対するフィリングタイプ (詳細は<>を参照)。 | conditions | 文字列 | バーを表示する状態 (詳細は<>を参照)。 |=== [[bar_items]] ==== アイテム 'items' オプションはバーアイテムをコンマ (画面上のアイテム同士に間隔を空ける) または "+" (間隔を空けない) で区切った文字列。 バーアイテムのリストは `/bar listitems` コマンドで表示されます。 アイテム名の前または後に文字を表示させることができます (英数字以外の文字、"-" または "_")。この文字はバー ('color_delim' オプション) で定義された区切り文字の色をつけてアイテムの前または後に表示されます。 アイテムを含むバーの例 "[time],buffer_number+:+buffer_plugin+.+buffer_name": .... ┌───────────────────────────────────────────────────────────────────────────┐ │[12:55] 3:irc/freenode.#weechat │ └───────────────────────────────────────────────────────────────────────────┘ .... 特殊構文を使うことで、バーアイテム: "@buffer:item" ("buffer" はバッファの完全な名前、"item" はバーアイテムの名前) を表示する際に強制的に指定されたバッファを利用することが可能です。 これはルートバーに現在のウィンドウで表示されない (またはどこにも表示されない) 特定のバッファのアイテムを表示させる際に便利です。 例: bitlbee のニックネームリストをルートバーに表示させる (バーが 'bitlist' で bitlbee サーバが 'bitlbee' の場合): ---- /set weechat.bar.bitlist.items "@irc.bitlbee.&bitlbee:buffer_nicklist" ---- [[bar_filling]] ==== フィリング フィリングタイプには 4 つの種類があります: * `horizontal`: 左から右に向かってアイテムを水平に表示。アイテム内に改行がある場合、空白を行区切りに利用します。 * `vertical`: 上から下に向かってアイテムを表示。アイテム内に改行がある場合、改行を行区切りに利用します。 * `columns_horizontal`: テキストを左寄せして、列形式でアイテムを表示。最初のアイテムは左上、2 番目は同じ行の 1 列右側。 * `columns_vertical`: テキストを左寄せして、列形式でアイテムを表示。最初のアイテムは左上、2 番目は同じ列の 1 行下側。 デフォルトバーである 'title'、'status'、'input' は 'horizontal' フィリング、'nicklist' は 'vertical' フィリング。 'nicklist' バーに対するフィリングの例: .... ┌───────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:54:15 peter | hey! │@carl │ │12:55:01 +Max | hello │@jessika│ │ │@maddy │ │ │%Diego │ │ │%Melody │ │ │+Max │ │ │ celia │ │ │ Eva │ │ │ freddy │ │ │ Harold^│ │ │ henry4 │ │ │ jimmy17│ │ │ jodie ▼│ │[12:55] [6] [irc/freenode] 3:#test(+n){24} │ │[@carl] █ │ └───────────────────────────────────────────────────────────────────────┘ filling_left_right = vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:54:15 peter | hey! │@carl lee │ │12:55:01 +Max | hello │@jessika louise │ │ │@maddy mario │ │ │%Diego mark │ │ │%Melody peter │ │ │+Max Rachel │ │ │ celia richard│ │ │ Eva sheryl │ │ │ freddy Vince │ │ │ Harold^ warren │ │ │ henry4 zack │ │ │ jimmy17 │ │ │ jodie │ │[12:55] [6] [irc/freenode] 3:#test(+n){24} │ │[@carl] █ │ └───────────────────────────────────────────────────────────────────────┘ filling_left_right = columns_vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │@carl %Diego celia Harold^ jodie mario Rachel Vince │ │@jessika %Melody Eva henry4 lee mark richard warren │ │@maddy +Max freddy jimmy17 louise peter sheryl zack │ │───────────────────────────────────────────────────────────────────────│ │ │ filling_top_bottom = columns_vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │@carl @jessika @maddy %Diego %Melody +Max celia Eva │ │ freddy Harold^ henry4 jimmy17 jodie lee louise mario │ │ mark peter Rachel richard sheryl Vince warren zack │ │───────────────────────────────────────────────────────────────────────│ │ │ filling_top_bottom = columns_horizontal ▲ .... [[bar_conditions]] ==== 状態 'conditions' オプションはバーを表示するか否かを評価する文字列です。 文字列は以下のいずれか: * 'active': 非アクティブ状態のウィンドウ * 'inactive': 非アクティブ状態のウィンドウ * 'nicklist': ニックネームリストが含まれるバッファのウィンドウ * 式: ブール値として評価 (<> コマンドを参照) 式に使える変数は以下: * `${active}`: ウィンドウがアクティブ状態の時に真 * `${inactive}`: ウィンドウが非アクティブ状態の時に真 * `${nicklist}`: ウィンドウに表示されるバッファがニックネームリストの場合に真。 式に使えるポインタは以下: * `${window}`: 状態が評価されたウィンドウ * `${buffer}`: 状態が評価されたウィンドウのバッファ ニックネームリストを持ち、ウィンドウ幅が 100 より大きい全てのバッファにニックネームリストバーを表示する例: ---- /set weechat.bar.nicklist.conditions "${nicklist} && ${window.win_width} > 100" ---- 上と同じだが、'&bitlbee' バッファでは常にニックネームリストを表示 (ウィンドウ幅が狭くても): ---- /set weechat.bar.nicklist.conditions "${nicklist} && (${window.win_width} > 100 || ${buffer.full_name} == irc.bitlbee.&bitlbee)" ---- [[bare_display]] === 最小限表示 "最小限表示" と呼ばれる特殊な表示状態を使うことで、(マウスを使って) 長い URL を簡単にクリックしたり、テキストを簡単に選択できるようになっています。 最小限表示は以下の機能を持っています: * 現在のバッファの内容だけを表示: 分割ウィンドウやバー等 (タイトル、ニックネームリスト、状態、入力、...) も表示しない * WeeChat マウスサポートを無効化 (有効化されていた場合): ターミナルでやるのと同じように URL をクリックしたりテキストを選択できます * ncurses を使わない、このため URL を行の最後で分断されることがなくなります。 最小限表示を有効化するデフォルトキーは key[alt-l] で、終了するには同じキーを押してください (また、デフォルトでは入力が変更された場合に最小限表示を終了します、<> オプションを参照)。 <> オプションを使えば、時間フォーマットを変更することも可能です。 <> コマンドを使えば、指定秒後に最小限表示を有効化することができます。 WeeChat が以下のような表示状態の場合: .... ┌───────────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:52:27 --> | Flashy (flashcode@weechat.org) has joined #test │@Flashy│ │12:52:27 -- | Nicks #test: [@Flashy @joe +weebot peter] │@joe │ │12:52:27 -- | Channel #test: 4 nicks (2 ops, 1 voice, 1 normal) │+weebot│ │12:52:27 -- | Channel created on Tue Jan 27 06:30:17 2009 │peter │ │12:54:15 peter | hey! │ │ │12:55:01 @joe | peter: hook_process: https://weechat.org/files/do │ │ │ | c/devel/weechat_plugin_api.en.html#_weechat_hook_ │ │ │ | process │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [6] [irc/freenode] 3:#test(+n){4}* [H: 4:#abc(2,5), 6] │ │[@Flashy(i)] hi peter!█ │ └───────────────────────────────────────────────────────────────────────────┘ .... 最小限表示では以下の様に表示されます: .... ┌───────────────────────────────────────────────────────────────────────────┐ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │12:52 --> Flashy (flashcode@weechat.org) has joined #test │ │12:52 -- Nicks #test: [@Flashy @joe +weebot peter] │ │12:52 -- Channel #test: 4 nicks (2 ops, 1 voice, 1 normal) │ │12:52 -- Channel created on Tue Jan 27 06:30:17 2009 │ │12:54 hey! │ │12:55 <@joe> peter: hook_process: https://weechat.org/files/doc/devel/weech│ │at_plugin_api.en.html#_weechat_hook_process │ └───────────────────────────────────────────────────────────────────────────┘ .... このため、ターミナルで問題なく 'joe' さんからの URL をクリックできます (もちろん、使用中のターミナルで URL をクリックできるように設定されていなければいけませんが)。 [[notify_levels]] === 通知レベル バッファに表示された各メッセージには 4 つのレベルが設定されています。レベルの低いものから順に: * 'low': 重要性の低いメッセージ (例えば irc の参加/退出/終了メッセージ) * 'message': ユーザからのメッセージ * 'private': プライベートバッファのメッセージ * 'highlight': ハイライトされたメッセージ それぞれのバッファには通知レベルが設定されており、 通知レベルに対応するメッセージの数がホットリストに表示されます。 デフォルトの通知レベルは <> オプションで指定し、 デフォルトは 'all' です。 [width="50%",cols="3m,10",options="header"] |=== | 通知レベル | ホットリストに追加されるメッセージのレベル | none | (無効) | highlight | 'highlight' + 'private' | message | 'highlight' + 'private' + 'message' | all | 'highlight' + 'private' + 'message' + 'low' |=== 通知レベルはバッファグループに対して設定することも可能で、例えば irc サーバ "freenode" に含まれる全てのバッファに対して設定する場合: ---- /set weechat.notify.irc.freenode message ---- "#weechat" チャンネルだけに対して、通知レベルを 'highlight' に設定する場合: ---- /set weechat.notify.irc.freenode.#weechat highlight ---- `/buffer` コマンドで、あるバッファに対する通知レベルを設定できます: ---- /buffer notify highlight ---- [[key_bindings]] === デフォルトのキー割り当て [[key_bindings_command_line]] ==== コマンドライン用のキー [width="100%",cols="^.^3,.^10,.^5",options="header"] |=== | キー | 説明 | コマンド | key[←] .2+| コマンドラインで前の文字に移動 .2+| `/input move_previous_char` | key[ctrl-b] | key[→] .2+| コマンドラインで次の文字に移動 .2+| `/input move_next_char` | key[ctrl-f] | key[ctrl-←] .2+| コマンドラインで前の単語に移動 .2+| `/input move_previous_word` | key[alt-b] | key[ctrl-→] .2+| コマンドラインで次の単語に移動 .2+| `/input move_next_word` | key[alt-f] | key[Home] .2+| コマンドラインで行頭に移動 .2+| `/input move_beginning_of_line` | key[ctrl-a] | key[End] .2+| コマンドラインで行末に移動 .2+| `/input move_end_of_line` | key[ctrl-e] | key[ctrl-c,b] | テキストを太字化するコードの挿入 | `/input insert \x02` | key[ctrl-c,c] | テキストに色をつけるコードの挿入 | `/input insert \x03` | key[ctrl-c,i] | テキストをイタリック体にするコードの挿入 | `/input insert \x1D` | key[ctrl-c,o] | テキスト色のリセットを行うコードの挿入 | `/input insert \x0F` | key[ctrl-c,v] | テキスト色の反転を行うコードの挿入 | `/input insert \x16` | key[ctrl-c,_] | テキストに下線を引くコードの挿入 | `/input insert \x1F` | key[Del] .2+| コマンドラインで次の文字を削除 .2+| `/input delete_next_char` | key[ctrl-d] | key[Backsp.] .2+| コマンドラインで前の文字を削除 .2+| `/input delete_previous_char` | key[ctrl-h] | key[ctrl-k] | コマンドラインでカーソルより後の文字列を削除 (削除された文字列はクリップボードに保存) | `/input delete_end_of_line` | key[ctrl-r] | バッファ中の履歴からテキスト検索 (<>を参照) | `/input search_text_here` | key[ctrl-t] | 文字の入れ替え | `/input transpose_chars` | key[ctrl-u] | コマンドラインでカーソルより前の文字列を削除 (削除された文字列はクリップボードに保存) | `/input delete_beginning_of_line` | key[ctrl-w] | コマンドラインで前の単語を削除 (削除された文字列はクリップボードに保存) | `/input delete_previous_word` | key[ctrl-y] | クリップボードの内容を貼り付け | `/input clipboard_paste` | key[ctrl-_] | コマンドラインの最後の動作をやり直す | `/input undo` | key[alt-_] | コマンドラインの最後の動作を取り消す | `/input redo` | key[Tab] | コマンドやニックネームを補完 (再度 key[Tab] することで次の補完候補を表示) | `/input complete_next` | key[shift-Tab] | 補完候補が無い場合: 部分補完を行う、補完候補が有る場合: 前の補完候補を表示 | `/input complete_previous` | key[Enter] .3+| コマンドを実行するか、メッセージを送信する (検索モードの場合: 検索の終了) .3+| `/input return` | key[ctrl-j] | key[ctrl-m] | key[↑] | 前のコマンド/メッセージを呼び出す (検索モードの場合: 上方向に検索) | `/input history_previous` | key[↓] | 次のコマンド/メッセージを呼び出す (検索モードの場合: 下方向に検索) | `/input history_next` | key[ctrl-↑] | グローバル履歴から前のコマンド/メッセージを呼び出す (すべてのバッファに対して共通の履歴) | `/input history_global_previous` | key[ctrl-↓] | グローバル履歴から次のコマンド/メッセージを呼び出す (すべてのバッファに対して共通の履歴) | `/input history_global_next` | key[alt-d] | コマンドラインで次の単語を削除 (削除された文字列はクリップボードに保存) | `/input delete_next_word` | key[alt-k] | キー入力を奪って、コマンドラインにコード (キーが割り当てられていればコマンド) を入力 | `/input grab_key_command` | key[alt-r] | コマンドラインへの入力をすべて削除 | `/input delete_line` | key[alt-s] | aspell の有効無効を切り替え | `/mute aspell toggle` |=== [[key_bindings_buffers_windows]] ==== バッファ / ウィンドウ用のキー [width="100%",cols="^.^3,.^10,.^5",options="header"] |=== | キー | 説明 | コマンド | key[ctrl-l] | 全ウィンドウを再描画 | `/window refresh` | key[ctrl-s,ctrl-u] | すべてのバッファに未読マークをセット | `/input set_unread` | key[ctrl-x] | 同じ番号を持つバッファにアタッチされていた場合、現在のバッファに移動 | `/input switch_active_buffer` | key[alt-x] | マージされたバッファに再ズーム (key[alt-x]: 全てのマージされたバッファを表示) | `/input zoom_merged_buffer` | key[PgUp] | バッファ履歴を 1 ページ分上方向にスクロール | `/window page_up` | key[PgDn] | バッファ履歴を 1 ページ分下方向にスクロール | `/window page_down` | key[alt-PgUp] | バッファ履歴を数行分上方向にスクロール | `/window scroll_up` | key[alt-PgDn] | バッファ履歴を数行分下方向にスクロール | `/window scroll_down` | key[alt-Home] | バッファ履歴を最初までスクロール | `/window scroll_top` | key[alt-End] | バッファ履歴を最後までスクロール | `/window scroll_bottom` | key[alt-←] .4+| 前のバッファに移動 .4+| `/buffer -1` | key[alt-↑] | key[ctrl-p] | key[F5] | key[alt-→] .4+| 後のバッファに移動 .4+| `/buffer +1` | key[alt-↓] | key[ctrl-n] | key[F6] | key[F7] | ウィンドウを前に移動 | `/window -1` | key[F8] | ウィンドウを後に移動 | `/window +1` | key[F9] | バッファタイトルを左方向にスクロール | `/bar scroll title * -30%` | key[F10] | バッファタイトルを右方向にスクロール | `/bar scroll title * +30%` | key[F11] | ニックネームリストを上方向にスクロール | `/bar scroll nicklist * -100%` | key[F12] | ニックネームリストを下方向にスクロール | `/bar scroll nicklist * +100%` | key[alt-F11] | ニックネームリストを一番上にスクロール | `/bar scroll nicklist * b` | key[alt-F12] | ニックネームリストを一番下にスクロール | `/bar scroll nicklist * e` | key[alt-a] | 変更のあった次のバッファに移動 (優先順位: ハイライト、新規メッセージ、その他) | `/input jump_smart` | key[alt-h] | ホットリスト (他のバッファにあった変更通知リスト) を消去 | `/input hotlist_clear` | key[alt-j,alt-f] | 最初のバッファに移動 | `/buffer -` | key[alt-j,alt-l] | 最後のバッファに移動 | `/buffer +` | key[alt-j,alt-r] | IRC 生バッファに移動 | `/server raw` | key[alt-j,alt-s] | IRC サーババッファに移動 | `/server jump` | key[alt-0...9] | 番号のバッファに移動 (0 = 10) | `/buffer *N` | key[alt-j,01...99] | 番号のバッファに移動 | `/buffer *NN` | key[alt-l] | 最小限表示の有効無効を切り替え | `/window bare` | key[alt-m] | マウスの有効無効を切り替え | `/mouse toggle` | key[alt-n] | 次のハイライトまでスクロール | `/window scroll_next_highlight` | key[alt-p] | 前のハイライトまでスクロール | `/window scroll_previous_highlight` | key[alt-u] | バッファを最初の未読行までスクロール | `/window scroll_unread` | key[alt-w,alt-↑] | 上のウィンドウに移動 | `/window up` | key[alt-w,alt-↓] | 下のウィンドウに移動 | `/window down` | key[alt-w,alt-←] | 左のウィンドウに移動 | `/window left` | key[alt-w,alt-→] | 右のウィンドウに移動 | `/window right` | key[alt-w,alt-b] | すべてのウィンドウサイズを均等に | `/window balance` | key[alt-w,alt-s] | 2 つのウィンドウを入れ替え | `/window swap` | key[alt-z] | 現在のウィンドウを最大化 (再度 key[alt-z] することで: 最初のウィンドウ状態に戻す、最大化前の状態) | `/window zoom` | key[alt-]key[<] | バッファ訪問履歴で前のバッファに移動 | `/input jump_previously_visited_buffer` | key[alt-]key[>] | バッファ訪問履歴で次のバッファに移動 | `/input jump_next_visited_buffer` | key[alt-/] | 最後に表示したバッファに移動 (バッファ移動前に表示していたウィンドウ) | `/input jump_last_buffer_displayed` | key[alt-=] | フィルタの有効無効を切り替え | `/filter toggle` | key[alt--] | 現在のバッファのフィルタの有効無効を切り替え | `/filter toggle @` |=== [[key_bindings_search_context]] ==== "検索" モード用のキー 以下のキーは "検索" モード (バッファ内のテキスト検索用に key[ctrl-r] が押された状態) でのみ有効です。 [width="100%",cols="^.^3,.^10,.^5",options="header"] |=== | キー | 説明 | コマンド | key[ctrl-r] | 検索タイプを切り替え: 文字列 (デフォルト)、正規表現 | `/input search_switch_regex` | key[alt-c] | 大文字小文字を区別して検索 | `/input search_switch_case` | key[Tab] | 検索範囲: メッセージ (デフォルト)、プレフィックス、プレフィックスとメッセージ | `/input search_switch_where` | key[↑] | 前のキーワードで検索 | `/input search_previous` | key[↓] | 次のキーワードで検索 | `/input search_next` | key[Enter] .3+| 現在の位置で検索を終了 .3+| `/input search_stop_here` | key[ctrl-j] | key[ctrl-m] | key[ctrl-q] | 検索を終了してバッファの最後までスクロール | `/input search_stop` |=== [[key_bindings_cursor_context]] ==== "カーソル" モード用のキー 以下のキーは "カーソル" モード (スクリーン上でカーソルを自由に動かせる状態) でのみ有効です。 [width="100%",cols="^.^3,^.^3,.^10,.^8",options="header"] |=== | キー | エリア | 説明 | コマンド | key[↑] | - | カーソルを上の行に移動 | `/cursor move up` | key[↓] | - | カーソルを下の行に移動 | `/cursor move down` | key[←] | - | カーソルを左の列に移動 | `/cursor move left` | key[→] | - | カーソルを右の列に移動 | `/cursor move right` | key[alt-↑] | - | カーソルを上のエリアに移動 | `/cursor move area_up` | key[alt-↓] | - | カーソルを下のエリアに移動 | `/cursor move area_down` | key[alt-←] | - | カーソルを左のエリアに移動 | `/cursor move area_left` | key[alt-→] | - | カーソルを右のエリアに移動 | `/cursor move area_right` | key[m] | チャット | メッセージを引用 | `hsignal:chat_quote_message;/cursor stop` | key[q] | チャット | プレフィックスとメッセージを引用 | `hsignal:chat_quote_prefix_message;/cursor stop` | key[Q] | チャット | 時間、プレフィックス、メッセージを引用 | `hsignal:chat_quote_time_prefix_message;/cursor stop` | key[b] | ニックネームリスト| ニックネームをバンする | `/window ${_window_number};/ban ${nick}` | key[k] | ニックネームリスト| ニックネームをキックする | `/window ${_window_number};/kick ${nick}` | key[K] | ニックネームリスト| ニックネームをバンとキックする | `/window ${_window_number};/kickban ${nick}` | key[q] | ニックネームリスト| ニックネームに対するクエリを開く | `/window ${_window_number};/query ${nick};/cursor stop` | key[w] | ニックネームリスト| ニックネームに対して whois を行う | `/window ${_window_number};/whois ${nick}` | key[Enter] .3+| - .3+| カーソルモードを終了 .3+| `/cursor stop` | key[ctrl-j] | key[ctrl-m] |=== [[key_bindings_mouse_context]] ==== "マウス" モード用のキー 以下のキーは "マウス" モード (マウスイベントが発生したとき) でのみ有効です。 [width="100%",cols="^.^3,^.^3,^.^3,.^10,.^8",options="header"] |=== | ボタン^(1)^ | ジェスチャー| エリア| 説明 | コマンド | ◾◽◽ | - | チャット | ウィンドウに移動 | `/window ${_window_number}` | ◾◽◽ | 左 | チャット | 前のバッファに移動 | `/window ${_window_number};/buffer +1` | ◾◽◽ | 右 | チャット | 次のバッファに移動 | `/window ${_window_number};/buffer +1` | ◾◽◽ | 左 (長く) | チャット | 最初のバッファに移動 | `/window ${_window_number};/buffer 1` | ◾◽◽ | 右 (長く) | チャット | 最後のバッファに移動 | `/window ${_window_number};/input jump_last_buffer` | ◾◽◽ | - | チャット (スクリプトバッファ) | スクリプトバッファで行選択 | `/script go ${_chat_line_y}` | ◽◽◾ | - | チャット (スクリプトバッファ) | スクリプトのインストール `/ 削除 | /script go ${_chat_line_y};/script installremove ${script_name_with_extension}` | ⇑ | - | チャット | バッファ履歴を上方向にスクロール | `/window scroll_up -window ${_window_number}` | ⇓ | - | チャット | バッファ履歴を下方向にスクロール | `/window scroll_down -window ${_window_number}` | ⇑ | - | チャット (スクリプトバッファ) | スクリプトバッファを 5 行上方向にスクロール | `/script up 5` | ⇓ | - | チャット (スクリプトバッファ) | スクリプトバッファで 5 行下方向にスクロール | `/script down 5` | key[ctrl-]⇑ | - | チャット | 水平左方向にスクロール | `/window scroll_horiz -window ${_window_number} -10%` | key[ctrl-]⇓ | - | チャット | 水平右方向にスクロール | `/window scroll_horiz -window ${_window_number} +10%` | ◾◽◽ | 上 | ニックネームリスト | ニックネームリストを 1 ページ分上方向にスクロール | `/bar scroll nicklist ${_window_number} -100%` | ◾◽◽ | 下 | ニックネームリスト | ニックネームリストを 1 ページ分下方向にスクロール | `/bar scroll nicklist ${_window_number} +100%` | ◾◽◽ | 上 (長く) | ニックネームリスト | ニックネームリストの最初に移動 | `/bar scroll nicklist ${_window_number} b` | ◾◽◽ | 下 (長く) | ニックネームリスト | ニックネームリストの最後に移動 | `/bar scroll nicklist ${_window_number} e` | ◾◽◽ | - | ニックネームリスト | ニックネームに対するクエリを開く | `/window ${_window_number};/query ${nick}` | ◽◽◾ | - | ニックネームリスト | ニックネームに対する whois を行う | `/window ${_window_number};/whois ${nick}` | ◾◽◽ | 左 | ニックネームリスト | ニックネームをキックする | `/window ${_window_number};/kick ${nick}` | ◾◽◽ | 左 (長く) | ニックネームリスト | ニックネームをキックとバンする | `/window ${_window_number};/kickban ${nick}` | ◽◽◾ | 左 | ニックネームリスト | ニックネームをバンする | `/window ${_window_number};/ban ${nick}` | ◽◽◾ | - | 入力 | マウスイベントを奪ってコマンドラインにコードを入力 | `/input grab_mouse_area` | ⇑ | - | 任意のバー | バーを -20% スクロール | `/bar scroll ${_bar_name} ${_window_number} -20%` | ⇓ | - | 任意のバー | バーを +20% スクロール | `/bar scroll ${_bar_name} ${_window_number} +20%` | ◽◾◽ | - | 任意の場所 | この場所でカーソルモードを開始 | `/cursor go ${_x},${_y}` |=== [NOTE] ^(1)^ "⇑" と "⇓" はホイールの上方向回転と下方向回転に対応します。 [[mouse]] === マウスサポート WeeChat はマウスクリックとマウスジェスチャーをサポートしています。 ローカル端末と screen/tmux の有無にかかわらず ssh 接続経由で利用可能です。 [[mouse_enable]] ==== マウスの有効化 起動時にマウスを有効化するには: ---- /set weechat.look.mouse on ---- マウスを有効化するには key[alt-m] を押すか、以下のコマンドを使います: ---- /mouse enable ---- キーにマウスの一時的な無効化を割り当てることができます。 例えば、 key[alt-x] キーにマウスを 10 秒間無効化する機能を割り当てるには: ---- /key bind meta-x /mouse toggle 10 ---- WeeChat でマウスが有効化されている場合、key[shift] 修飾キーで選択やクリックができます。これでマウスが無効化されている場合と同じ作業が行えます (iTerm 等の端末では key[shift] の代わりに key[alt] を使ってください)。 [NOTE] マウスに関するトラブルがあれば 'WeeChat FAQ' を参照してください。 [[mouse_bind_events]] ==== コマンドに対してマウスイベントを割り当てる WeeChat はデフォルトマウスイベントの多くを定義しています (<>を参照)。 `/key` コマンドで "mouse" コンテキストを指定することで割り当てを追加、変更できます (詳しい使い方は <> コマンドを参照)。 イベント名には修飾キー (任意)、ボタン/ホイール名、ジェスチャー (任意) を利用できます。異なるイベントは "-" で分割してください。 修飾キーリスト: [width="50%",cols="3m,4",options="header"] |=== | 修飾キー | 説明 | ctrl | key[ctrl] キー | alt | key[alt] キー | ctrl-alt | key[ctrl-]key[alt] キー |=== ボタン/ホイールのリスト: [width="50%",cols="3m,4",options="header"] |=== | ボタン/ホイール | 説明 | button1 | 左ボタンクリック | button2 | 右ボタンクリック | button3 | 中ボタンクリック (多くの場合ホイールクリック) | button4 ... button9 | その他のボタンクリック | wheelup | ホイール (上方向) | wheeldown | ホイール (下方向) |=== ジェスチャーのリスト (ボタンのみ対応、ホイール未対応): [width="50%",cols="3m,4",options="header"] |=== | ジェスチャー | 距離 | gesture-up | 3 ... 19 | gesture-up-long | ≥ 20 | gesture-down | 3 ... 19 | gesture-down-long | ≥ 20 | gesture-left | 3 ... 39 | gesture-left-long | ≥ 40 | gesture-right | 3 ... 39 | gesture-right-long | ≥ 40 |=== 未完了イベントのリスト (ボタンのみ、プラグイン/スクリプトで便利): [width="50%",cols="3m,4",options="header"] |=== | イベント | 説明 | event-down | マウスボタンが押され、離されていない状態 | event-drag | マウスボタンが押された状態でマウスが動かされた |=== イベントの表記例: * `button1` * `ctrl-button1` * `button1-gesture-right` * `button1-event-down` * `button1-event-drag` * `alt-button2-gesture-down-long` * `wheelup` * `ctrl-alt-wheeldown` * ... [TIP] "mouse" イベントにキーを割り当てる場合、イベント名の最初または最後に `*` を使うことで複数のイベントにマッチさせることができます。例えば `button1-gesture-*` は左クリックを利用したすべてのジェスチャーにマッチします。 [TIP] `/input grab_mouse` コマンドの後にマウスを動かすことでコマンドラインにマウスイベントが入力されます。 これにより対応するイベントを確認できます。 [[command_line]] === コマンドライン WeeChat コマンドライン (ウィンドウの一番下にあります) はコマンドの実行やバッファにテキストを送信するために利用します。 [[command_line_syntax]] ==== 文法 コマンドは "/" 文字で始まり、コマンドの名前を続けます。 例えば、すべてのオプションを表示するには: ---- /set ---- "/" が最初に無い場合、そのテキストはバッファに送信されます。例えば、'hello' というテキストをバッファに送信するには: ---- hello ---- "/" 文字から始まるテキストを送信したい場合、は 2 重に "/" をつけます。例えば、'/set' というテキストを現在のバッファに送信するには: ---- //set ---- [[command_line_colors]] ==== 色コード IRC 等のプラグインでは、以下の色コードと属性を利用できます (key[ctrl-c] の後に、オプションとともに以下のキーを押してください): key[ctrl-c,b]:: テキストを太字に key[ctrl-c,c], key[xx]:: テキスト表示色を `xx` に (以下の色リストを参照) key[ctrl-c,c], key[xx]key[,]key[yy]:: テキスト表示色を `xx` に、背景色を `yy` に (以下の色リストを参照) key[ctrl-c,i]:: テキストをイタリック体に key[ctrl-c,o]:: テキスト表示色と属性をリセット key[ctrl-c,v]:: テキストを反転 (テキスト表示色と背景色の入れ替え) key[ctrl-c,_]:: テキストに下線を引く [NOTE] 同じコードで (色コードを入力せずに key[ctrl-c,c] を使うことで) 属性をキャンセルすることができます。 key[ctrl-c,c] 用の色コード: include::autogen/user/irc_colors.asciidoc[] [NOTE] 端末で利用可能なすべての色を表示するには、WeeChat で `/color` を実行した後 key[alt-c] を入力するか、端末で以下のコマンドを実行してください: `weechat --colors`。 例: "こんにちは皆さん!" の "こんにちは" を太字の明るい青、"皆さん" を下線付きの明るい赤に表示したい場合: ---- ^Cc12^Cbこんにちは^Cb^Cc04^C_皆さん^C_^Cc! ---- [NOTE] irc プラグインでは、<> を使ってこれらの色を別の色に対応付けることができます。 [[colors]] === 色 WeeChat ではバーやチャットエリアにおけるテキスト表示に 256 個の色ペアを利用できます (この機能を利用するには WeeChat が実行されているターミナルが 256 色表示に対応している必要があります)。 'TERM' 環境変数の値によって、WeeChat で利用できる色と色ペアに以下の制限があります: [width="50%",cols="8,>2,>2",options="header"] |=== | $TERM | 色 | ペア ^(1)^ | "rxvt-unicode", "xterm", ... | 88 | 256 | "rxvt-256color", "xterm-256color", ... | 256 | 32767 | "screen" | 8 | 64 | "screen-256color" | 256 | 32767 |=== [NOTE] ^(1)^ 端末が 256 ペア以上の表示をサポートしていても、WeeChat では ncurses の制限により 256 ペア以上の表示は行えません。 `weechat --colors` を実行するか、`/color` コマンドをin WeeChat の中で実行することで、色表示の制限を確認できます。 256 色を利用したい場合に推奨される 'TERM' 環境変数の値は: * screen の中: 'screen-256color' * screen の外: 'xterm-256color' 、'rxvt-256color' 、'putty-256color' 、... [NOTE] 'TERM' 環境変数の値に上の値を設定するには、"ncurses-term" パッケージをインストールする必要があるかもしれません。 screen を使っている場合、'~/.screenrc' に以下の内容を追加してください: ---- term screen-256color ---- 'TERM' 変数が間違った値に設定された状態で WeeChat が起動完了している場合は、以下の 2 つのコマンドを使って変数の値を変更してください: ---- /set env TERM screen-256color /upgrade ---- [[colors_basic]] ==== 基本色 WeeChat における基本色とは: [width="50%",cols="^3m,8",options="header"] |=== | 名前 | 色 | default | デフォルトの端末色 (背景色を透過色とする) | black | 黒 | darkgray | 暗い灰色 | red | 暗い赤 | lightred | 明るい赤 | green | 暗い緑色 | lightgreen | 明るい緑色 | brown | 茶色 | yellow | 黄色 | blue | 暗い青 | lightblue | 明るい青 | magenta | 暗い赤紫色 | lightmagenta | 明るい赤紫色 | cyan | 暗い青緑色 | lightcyan | 明るい青緑色 | gray | 灰色 | white | 白 |=== [[colors_extended]] ==== 拡張色 WeeChat はスクリーンに色が表示された時点で色ペアを動的に割り当てます (バッファとバーを表示する時点で)。 基本色に加えて、1 番 から端末の対応状況に依存する番号までの色番号を利用できます。 `/color` コマンドで現在の色と色制限を確認できます。key[alt-c] をタイプすることで、一時的に端末色を選択された色に変更できます。 例えば、バッファ中のに表示される時刻をオレンジ色にしたい場合、以下のようにしてください: ---- /set weechat.color.chat_time 214 ---- ステータスバーの色を非常に暗い緑色にしたい場合: ---- /set weechat.bar.status.color_bg 22 ---- [[colors_aliases]] ==== 別名 `/color alias` コマンドを使えば色の別名を追加できます。 追加後は任意の色関連オプションで別名を使えます。 例: ---- /color alias 214 orange /set weechat.color.chat_delimiters orange ---- [[colors_attributes]] ==== 属性 色に対していくつかの属性を付加することができます。1 つ以上の属性を色名又は色番号の前に付加できます: * `*` : テキストを太字に * `!` : テキストを反転 * `/` : テキストをイタリック体に * `_` : テキストに下線を引く * `|` : 属性を保持: 色を変えた際に太字/反転/下線属性をリセットしない 例えば、自分自身のニックネームの表示色を白にして、下線を引きたい場合: ---- /set weechat.color.chat_nick_self _white ---- ステータスバーの時刻の表示色を橙色にして、下線を引いて、太字にしたい場合: ---- /set weechat.color.status_time *_214 ---- デフォルト端末色 (-1) に対して属性を設定したい場合、端末色番号の最大値よりも大きな値を利用してください。 例えば、WeeChat における色番号の最大値は 99999 です。 端末の表示色に太字の属性を付加する例: ---- /set weechat.color.status_time *99999 ---- [[secured_data]] === 暗号化データ [[secured_data_storage]] ==== データの保存 WeeChat はパスワード及び 'sec.conf' ファイルに保存されている個人データを暗号化することができます。 この設定ファイルは他のどのファイルよりも先に読まれ、ファイルに保存されている値を WeeChat 及びプラグイン/スクリプトのオプションで使うことができます。 'sec.conf' に含まれるデータを暗号化するパスフレーズを設定することが可能です。これは必須ではありませんが、パスフレーズを設定することを強く勧めます。パスフレーズを設定しない場合、データは平文でファイルに保存されます。 ---- /secure passphrase this is my passphrase ---- パスフレーズを設定した場合、WeeChat の起動時にパスフレーズの入力が求められるようになります (`/upgrade` 時には求められません)。 この挙動を変更し、パスフレーズを保存したファイルを使うことも可能です (<> オプションを参照してください)。 [[secured_data_encryption]] ===== 暗号化 データの暗号化は 3 段階に分けて行われます: . パスフレーズから鍵を生成 (任意の salt を加えます)。 . 暗号化するデータのハッシュを計算。 . ハッシュとデータを暗号化 (出力: salt + 暗号化済みのハッシュ/データ)。 [NOTE] ブロック暗号モードは 'CFB' です。 結果は 16 進数文字列として 'sec.conf' ファイルに保存されます、例: ---- [data] __passphrase__ = on freenode = "53B1C86FCDA28FC122A95B0456ABD79B5AB74654F21C3D099A6CCA8173239EEA59533A1D83011251F96778AC3F5166A394" ---- [[secured_data_decryption]] ===== 復号化 データの復号化は 3 段階に分けて行われます: . salt とパスフレーズを使って鍵を生成。 . ハッシュとデータを復号化。 . 復号化したハッシュとデータのハッシュが同じことを確認。 [[secured_data_manage]] ==== 暗号化データの管理 暗号化データを追加するには、`/secure set` を使ってください、'freenode' IRC サーバのパスワードを設定する例: ---- /secure set freenode mypassword ---- 利便性を考慮して、暗号化データを専用のバッファに表示できるようになっています (値を見るにはバッファで key[alt-v]、以下のコマンドを実行してください: ---- /secure ---- 例えばパスワードなどの個人データを含むオプションで暗号化データを使うことができます、フォーマット: "${sec.data.xxx}" ここで "xxx" は暗号化データの名前です (`/secure set xxx ...` のように使った)。 + 利用できるオプションの完全なリストはを見るには、`/help secure` を使ってください。 例えば上の 'freenode' パスワードを <>で使うには: ---- /set irc.server.freenode.sasl_password "${sec.data.freenode}" ---- [[options_and_commands]] === オプションとコマンド [[sec_options]] ==== 保護データのオプション (sec.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | crypt | /set sec.crypt.* | 暗号化に関するオプション | data | <> | 保護データ |=== オプション: include::autogen/user/sec_options.asciidoc[] [[weechat_options]] ==== WeeChat オプション (weechat.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | debug | <> + /set weechat.debug.* | core とプラグインのデバッグレベル (オプションをセクションに追加/削除出来ます) | startup | /set weechat.startup.* | 起動オプション | look | /set weechat.look.* | 外観 | palette | <> + /set weechat.palette.* | 色の別名 (オプションをセクションに追加/削除出来ます) | color | /set weechat.color.* | 色 | completion | /set weechat.completion.* | 補完オプション | history | /set weechat.history.* | 履歴オプション (コマンドとバッファ) | proxy | <> + /set weechat.proxy.* | プロキシオプション | network | /set weechat.network.* | ネットワーク/SSL オプション | bar | <> + /set weechat.bar.* | バーオプション | layout | <> | レイアウト | notify | <> | バッファに対する通知レベル (オプションをセクションに追加/削除出来ます) | filter | <> | フィルタ | key | <> | デフォルトコンテキストのキー | key_search | <> | 検索コンテキストのキー | key_cursor | <> | カーソルコンテキストのキー | key_mouse | <> | マウスコンテキストのキー |=== オプション: include::autogen/user/weechat_options.asciidoc[] [[weechat_commands]] ==== WeeChat コマンド include::autogen/user/weechat_commands.asciidoc[] [[plugins]] == プラグイン プラグインとは動的ライブラリのことで、C 言語で書かれてコンパイルされています。 プラグインは WeeChat によって読み込まれます。 GNU/Linux の場合、プラグインファイルは ".so" という拡張子を持ち、Windows の場合、".dll" です。 見つかったプラグインは WeeChat の起動時に自動的に読み込まれます。WeeChat の起動時にプラグインを読み込むか否かは選択可能です。 'プラグイン' と 'スクリプト' の違いを明らかにすることは重要です: 'プラグイン' とは `/plugin` コマンドで読み込まれるコンパイル済みバイナリファイルです。これに対して、 'スクリプト' とは `/python` 等のコマンドで 'python' 等のプラグインとともに読み込まれるテキストファイルです。 `/plugin` コマンドを使うことで、プラグインのロード/アンロード、 ロード済みプラグインの表示を行うことができます。 あるプラグインをアンロードした場合、 アンロードしたプラグインが作成したバッファはすべて自動的に閉じられます。 プラグインをロード、アンロード、ロード済みプラグインを表示する例: ---- /plugin load irc /plugin unload irc /plugin list ---- デフォルトプラグインのリスト: [width="100%",cols="^1,5",options="header"] |=== | プラグイン | 説明 | alias | コマンドの別名を定義 | aspell | コマンドラインのスペルチェック | charset | バッファの文字コードに従ってデコード/エンコード | exec | WeeChat 内部から外部コマンドを実行 | fifo | 外部から WeeChat にコマンドを送信するための FIFO パイプ | irc | IRC チャットプロトコル | logger | バッファの内容をファイルに保存 | relay | ネットワーク経由でデータを中継 | script | スクリプトマネージャ | python | Python スクリプト API | perl | Perl スクリプト API | ruby | Ruby スクリプト API | lua | Lua スクリプト API | tcl | Tcl スクリプト API | guile | Guile (scheme) スクリプト API | javascript | Javascript スクリプト API | trigger | WeeChat およびプラグインが発生させたイベントに対するテキスト置換とコマンド実行 | xfer | ファイル転送とダイレクトチャット |=== API を使ったプラグインやスクリプトの開発についてより詳しく学ぶには、'WeeChat プラグイン API リファレンス' 又は 'WeeChat スクリプト製作ガイド' を参照してください。 [[alias_plugin]] === Alias プラグイン Alias プラグインを使うことで、コマンドの別名を定義できます (WeeChat だけでなく他のプラグインが提供するコマンドの別名を定義することもできます)。 [[alias_commands]] ==== コマンド include::autogen/user/alias_commands.asciidoc[] [[aspell_plugin]] === Aspell プラグイン Aspell プラグインを使うことで、コマンドラインに入力した文字列のスペルチェックができます。 バッファごとに異なる言語に対するスペルチェックを実行できます。 [[aspell_options]] ==== オプション (aspell.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | color | /set aspell.color.* | 色 | check | /set aspell.check.* | スペルチェックの操作コマンド | dict | <> + /set aspell.dict.* | バッファが利用するディレクトリ (オプションをセクションに追加/削除出来ます) | option | /set aspell.option.* | <> (オプションをセクションに追加/削除出来ます) |=== オプション: include::autogen/user/aspell_options.asciidoc[] [[aspell_commands]] ==== コマンド include::autogen/user/aspell_commands.asciidoc[] [[aspell_speller_options]] ==== Speller オプション Speller オプションは aspell 設定の "option" セクションにあるオプションを追加して定義します。 ここで利用するオプション名は aspell 設定オプションと同じものです。 オプションのリストはシェルで以下のコマンドを実行することで確認できます: ---- $ aspell config ---- 例えば、"ignore-case" オプションを有効化するには: ---- /set aspell.option.ignore-case "true" ---- [[aspell_suggestions]] ==== 修正候補 "aspell_suggest" バーアイテム内に修正候補が表示されます。修正候補の数は 'aspell.check.suggestions' オプションで設定します。 修正候補を利用するには、'aspell.check.suggestions' オプションをゼロ以上の整数に設定し、'status' バーなどに "aspell_suggest" バーアイテムを追加してください。 英語辞書 (`en`) を用いた修正候補の例: .... │[12:55] [6] [irc/freenode] 3:#test(+n){4} [print,prone,prune] │ │[@Flashy] prinr █ │ └─────────────────────────────────────────────────────────────────────────────────┘ .... 英語とフランス語辞書 (`en,fr`) を用いた修正候補の例: .... │[12:55] [6] [irc/freenode] 3:#test(+n){4} [print,prone,prune/prime,primer,primé] │ │[@Flashy] prinr █ │ └─────────────────────────────────────────────────────────────────────────────────┘ .... [[charset_plugin]] === Charset プラグイン Charset プラグインを使うことで、文字コードに従ってデータのデコードとエンコードができます。 デコード/エンコード用にデフォルトの文字コードが設定されていますが、 それぞれのバッファ (バッファグループ) に対して個別に文字コードを設定することもできます。 このプラグインの導入は任意ですが、導入を推奨します: このプラグインがロードされていない場合、WeeChat が読み書きできるデータは UTF-8 データのみになります。 Charset プラグインは WeeChat によって自動的にロードされるべきです。 プラグインがロードされていることを確認するには、以下のようにしてください: ---- /charset ---- コマンドが見つからない場合、以下のコマンドでプラグインをロードしてください: ---- /plugin load charset ---- プラグインが見つからない場合、文字コードサポートを有効化した状態で WeeChat を再コンパイルしてください。 Charset プラグインがロードされた場合、端末文字コードと内部文字コードが表示されます。 端末文字コードはロケールに依存し、内部文字コードは UTF-8 です。 例: .... charset: terminal: ISO-8859-15, internal: UTF-8 .... [[charset_options]] ==== オプション (charset.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | default | /set charset.default.* | デフォルトのデコード/エンコード文字セット | decode | <> + /set charset.decode.* | バッファのデコード文字セット (オプションをセクションに追加/削除出来ます) | encode | <> + /set charset.encode.* | バッファのエンコード文字セット (オプションをセクションに追加/削除出来ます) |=== オプション: include::autogen/user/charset_options.asciidoc[] [[charset_commands]] ==== コマンド include::autogen/user/charset_commands.asciidoc[] [[charset_set]] ==== 文字コードの設定 グローバルデコード文字コードとエンコード文字コードを設定するには、`/set` コマンドを使ってください。 例: ---- /set charset.default.decode ISO-8859-15 /set charset.default.encode ISO-8859-15 ---- グローバルデコード文字コードが設定されていない場合 (例えば Charset プラグインを始めてロードした場合)、これは自動的に端末の文字コードか (UTF-8 でなければ) 、デフォルトの 'ISO-8859-1' に設定されます。 デフォルトのエンコード文字コードはありません。従って、内部文字コード (UTF-8) が使われます。 IRC サーバの文字コードを設定するには、サーババッファで `/charset` コマンドを使ってください。 文字コードのみを引数として与えた場合、この文字コードがデコードとエンコードに利用されます。 例: ---- /charset ISO-8859-15 ---- これは以下と等価です: ---- /charset decode ISO-8859-15 /charset encode ISO-8859-15 ---- IRC チャンネル (またはプライベートメッセージ) の文字コードを設定するには、 サーバの文字コード設定と同様のコマンドをチャンネル (またはプライベートメッセージ) バッファで使ってください。 IRC サーバの全てのチャンネルおよびプライベートバッファに対する文字コードを設定するには: ---- /set charset.encode.irc.freenode ISO-8859-15 ---- すべての文字コード設定を確認するには、以下のコマンドを利用してください: ---- /set charset.* ---- [[charset_troubleshooting]] ==== トラブルシューティング 文字コードに関する問題があれば、'WeeChat FAQ' を参照してください。 [[exec_plugin]] === exec プラグイン `/exec` コマンドを使うことで WeeChat 内部から外部コマンドを実行し、その結果を表示したりバッファに送信することが可能になります。 [[exec_options]] ==== オプション (exec.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | command | /set exec.command.* | コマンドに対するオプション | color | /set exec.color.* | 色 |=== オプション: include::autogen/user/exec_options.asciidoc[] [[exec_commands]] ==== コマンド include::autogen/user/exec_commands.asciidoc[] [[fifo_plugin]] === Fifo プラグイン 外部から WeeChat を操作するには、FIFO パイプにコマンドやテキストを書き込んでください ("plugins.var.fifo.fifo" オプションが有効化されている必要がありますが、デフォルトで有効化されているはずです)。 FIFO パイプは '~/.weechat/' の下にあり、'weechat_fifo_xxxx' のような名前になっています ('xxxx' は実行中の WeeChat のプロセス ID (PID) です)。 FIFO パイプに書き込むコマンド/テキストの文法は以下の例の一つです: .... plugin.buffer *テキストまたはコマンド *テキストまたはコマンド .... 例: * IRC サーバ freenode のニックネームを "newnick" に変更する: ---- $ echo 'irc.server.freenode */nick newnick' >~/.weechat/weechat_fifo_12345 ---- * IRC の #weechat チャンネルに対してテキストを送信: ---- $ echo 'irc.freenode.#weechat *hello!' >~/.weechat/weechat_fifo_12345 ---- * 現在のバッファに対してテキストを送信: ---- $ echo '*hello!' >~/.weechat/weechat_fifo_12345 ---- * Python スクリプトのアンロードとロードを行う 2 つのコマンドを送信 (複数のコマンドは "\n" で分割してください): ---- $ printf '%b' '*/python unload\n*/python autoload\n' >~/.weechat/weechat_fifo_12345 ---- 実行中の WeeChat すべてに対してコマンドを送信するスクリプトは以下のように書けます。例えば: [source,shell] ---- #!/bin/sh if [ $# -eq 1 ]; then for fifo in ~/.weechat/weechat_fifo_* do printf '%b\n' "$1" >"$fifo" done fi ---- このスクリプトを "auto_weechat_command" というファイル名で保存した場合、以下のように実行できます: ---- $ ./auto_weechat_command 'irc.freenode.#weechat *hello' ---- [[irc_plugin]] === IRC プラグイン IRC プラグインは IRC プロトコルに従って他の人と会話を行うために設計されています。 マルチサーバに対応し、DCC チャットとファイル転送 (xfer プラグインを使います。 <> を参照) を含む全ての IRC コマンドをサポートしています。 [[irc_command_line_options]] ==== コマンドラインオプション 以下のように 1 つ以上の IRC サーバに対応する URL を引数として与えることができます: ---- irc[6][s]://[nick[:password]@]irc.example.org[:port][/channel][,channel[...]] ---- 'nono' というニックネームを使って 'chat.freenode.net' ホストのデフォルトポート (6667) で稼働中の IRC サーバ上の '#weechat' と '#toto' チャンネルに参加する例: ---- $ weechat irc://nono@chat.freenode.net/#weechat,#toto ---- [[irc_options]] ==== オプション (irc.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | look | /set irc.look.* | 外観 | color | /set irc.color.* | 色 | network | /set irc.network.* | ネットワークオプション | msgbuffer | /set irc.msgbuffer.* | <> (オプションをセクションに追加/削除出来ます) | ctcp | /set irc.ctcp.* | <> (オプションをセクションに追加/削除出来ます) | ignore | <> | 無視ユーザ | server_default | /set irc.server_default.* | サーバに対するデフォルト値 (サーバオプションが定義されていない場合に利用されます) | server | <> + /set irc.server.* | サーバ |=== オプション: include::autogen/user/irc_options.asciidoc[] [[irc_commands]] ==== コマンド include::autogen/user/irc_commands.asciidoc[] [[irc_ssl_certificates]] ==== SSL 証明書 SSL を使って IRC サーバに接続する場合、WeeChat はデフォルトで接続が完全に信頼できるものかどうかを確認します。 以下のオプションで SSL 接続を設定します: weechat.network.gnutls_ca_file:: 認証局ファイルへのパス (デフォルト: "%h/ssl/CAs.pem") irc.server.xxx.ssl_cert:: 自動的にニックネームを確認するために利用される SSL 証明書ファイル (例えば oftc サーバにおける CertFP の場合、以下を確認してください) irc.server.xxx.ssl_dhkey_size:: Diffie-Hellman キー交換の際に利用される鍵サイズ (デフォルト: 2048) irc.server.xxx.ssl_verify:: SSL 接続が完全に信頼できることの確認を行う (デフォルトで有効) [NOTE] "ssl_verify" オプションはデフォルトで有効です、したがって厳密な確認が行われ、0.3.1 より前のバージョンでは信頼性の確認に成功していたものが失敗する場合もあります。 [[irc_connect_oftc_with_certificate]] ===== 最初の例: oftc に接続して、証明書を確認 * シェルを使って証明書をインポート: ---- $ mkdir -p ~/.weechat/ssl $ wget -O ~/.weechat/ssl/CAs.pem http://www.spi-inc.org/ca/spi-cacert.crt ---- 注意: CAs.pem ファイル中で複数の証明書を連結することもできます。 * WeeChat では、"oftc" サーバが既に追加されています: ---- /connect oftc ---- [[irc_connect_oftc_with_certfp]] ===== 2 番目の例: CertFP を使って oftc に接続 * シェルで証明書を作成: ---- $ mkdir -p ~/.weechat/ssl $ cd ~/.weechat/ssl $ openssl req -nodes -newkey rsa:2048 -keyout nick.pem -x509 -days 365 -out nick.pem ---- * WeeChat では、"oftc" サーバが既に追加されています: ---- /set irc.server.oftc.ssl_cert "%h/ssl/nick.pem" /connect oftc /msg nickserv cert add ---- より詳しい情報は http://www.oftc.net/oftc/NickServ/CertFP を確認してください。 [[irc_sasl_authentication]] ==== SASL 認証 WeeChat は SASL 認証をサポートします、以下の認証メカニズムを利用できます: * 'plain': 平文パスワード (デフォルト) * 'ecdsa-nist256p-challenge': 公開鍵/秘密鍵を使うチャレンジ認証 * 'external': クライアント側 SSL 証明書 * 'dh-blowfish': blowfish 暗号パスワード * 'dh-aes': AES 暗号パスワード [NOTE] "dh-blowfish" メカニズムを利用する場合、"gcrypt" ライブラリが WeeChat のコンパイル時に必要です (<>を参照)。 サーバオプション: * 'sasl_mechanism': 利用する認証メカニズム (上記参照) * 'sasl_timeout': 認証時のタイムアウト (秒単位) * 'sasl_fail': 認証に失敗した場合の挙動 * 'sasl_username': ユーザ名 (ニックネーム) * 'sasl_password': パスワード * 'sasl_key': ECC 秘密鍵を含むファイル ('ecdsa-nist256p-challenge' 用) [[irc_sasl_ecdsa_nist256p_challenge]] ===== SASL ECDSA-NIST256P-CHALLENGE 認証 ECDSA-NIST256P-CHALLENGE を使って認証を行うためには、秘密鍵を作成してください (接続の際にパスワードは不要です)。 鍵を作成するには、以下のコマンドを使ってください: ---- $ openssl ecparam -genkey -name prime256v1 >~/.weechat/ecdsa.pem ---- 公開鍵を (base64 エンコード形式で) 作成するには、以下のコマンドを使ってください: ---- $ openssl ec -noout -text -conv_form compressed -in ~/.weechat/ecdsa.pem | grep '^pub:' -A 3 | tail -n 3 | tr -d ' \n:' | xxd -r -p | base64 ---- サーバに接続、本人確認 (例えば "nickserv identify" を使って)、nickserv を使ってアカウントに公開鍵を設定 (アカウントの公開鍵に base64 文字列を指定する): ---- /connect freenode /msg nickserv identify your_password /msg nickserv set pubkey Av8k1FOGetUDq7sPMBfufSIZ5c2I/QYWgiwHtNXkVe/q ---- サーバの SASL オプションを設定: ---- /set irc.server.freenode.sasl_mechanism ecdsa-nist256p-challenge /set irc.server.freenode.sasl_username "your_nickname" /set irc.server.freenode.sasl_key "%h/ecdsa.pem" ---- サーバに再接続: ---- /reconnect freenode ---- [[irc_tor_freenode]] ==== TOR/SASL を使って Freenode に接続する場合 SSL に加えて、Freenode サーバは TOR (https://www.torproject.org/) 経由の接続をサポートしています。TOR とはバーチャルトンネルのネットワークで、 これを使うことで個人やグループがインターネット利用に伴うプライバシーとセキュリティを向上させることができます。 最初に、TOR をインストールしてください。Debian (とその派生ディストリビューション) の場合: ---- $ sudo apt-get install tor ---- WeeChat で TOR サービスを使った socks5 プロキシを作成してください (ホスト名/IP アドレス、ポート番号は TOR の設定に依存します): ---- /proxy add tor socks5 127.0.0.1 9050 ---- そして、新しいサーバを追加します。例えば: ---- /server add freenode-tor p4fsi4ockecnea7l.onion ---- TOR プロキシを設定: ---- /set irc.server.freenode-tor.proxy "tor" ---- SASL 認証を設定: ---- /set irc.server.freenode-tor.sasl_username "your_nickname" /set irc.server.freenode-tor.sasl_password "your_password" ---- 最後に、サーバに接続してください: ---- /connect freenode-tor ---- Freenode と TOR に関するより詳しい情報: http://freenode.net/irc_servers.shtml#tor [[irc_smart_filter_join_part_quit]] ==== 参加/退出/終了メッセージに対するスマートフィルタ チャンネル内での発言が過去 X 分間なかった場合に参加/退出/終了メッセージをフィルタリングするスマートフィルタが利用できます。 スマートフィルタはデフォルトで有効化されていますが、 バッファ内のメッセージを隠すにはフィルタを追加する必要があります。例えば: ---- /filter add irc_smart * irc_smart_filter * ---- 特定のチャンネルのみ、またはある名前で始まるチャンネルに対してフィルタを作成することもできます。 (`/help filter` を参照): ---- /filter add irc_smart_weechat irc.freenode.#weechat irc_smart_filter * /filter add irc_smart_weechats irc.freenode.#weechat* irc_smart_filter * ---- 以下のコマンドで参加メッセージだけ、又は退出/終了メッセージだけを隠すこともできます: ---- /set irc.look.smart_filter_join on /set irc.look.smart_filter_quit on ---- 遅延時間 (分単位) を設定することもできます: ---- /set irc.look.smart_filter_delay 5 ---- 過去 5 分間あるニックネームからの発言が無かった場合、 このニックネームに対する参加または退出/終了メッセージがチャンネルから隠されます。 [[irc_ctcp_replies]] ==== CTCP 応答 CTCP 応答をカスタマイズしたり、いくつかの CTCP 要求をブロック (無応答) することができます。 例えば、CTCP "VERSION" 要求に対する応答をカスタマイズするには、以下のコマンドを使ってください: ---- /set irc.ctcp.version "I'm running WeeChat $version, it rocks!" ---- CTCP "VERSION" 要求をブロックする (要求に対する応答を行わない) には、空文字列を設定してください: ---- /set irc.ctcp.version "" ---- 未定義の CTCP 要求に対する応答もカスタマイズできます。例えば CTCP "BLABLA" 要求に対する応答を以下のように設定できます: ---- /set irc.ctcp.blabla "This is my answer to CTCP BLABLA" ---- 特定のサーバに対して CTCP 応答をカスタマイズするには、CTCP 名の前に内部サーバ名をつけてください: ---- /set irc.ctcp.freenode.version "WeeChat $version (for freenode)" ---- 標準の CTCP 応答を復元するには、オプションを削除してください: ---- /unset irc.ctcp.version ---- 以下のコードを設定値に含めることが可能です。これらのコードは CTCP 応答時に自動的に WeeChat によって展開されます: [width="100%",cols="^2l,4,8",options="header"] |=== | コード | 説明 | 値/例 | $clientinfo | サポートしている CTCP オプションのリスト | `ACTION DCC CLIENTINFO FINGER PING SOURCE TIME USERINFO VERSION` | $version | WeeChat バージョン | `0.4.0-dev` | $versiongit | WeeChat バージョン + git バージョン ^(1)^ | `0.4.0-dev (git: v0.3.9-104-g7eb5cc4)` | $git | git バージョン ^(1)^ | `v0.3.9-104-g7eb5cc4` | $compilation | WeeChat コンパイル日時 | `Dec 16 2012` | $osinfo | OS に関する情報 | `Linux 2.6.32-5-amd64 / x86_64` | $site | WeeChat ウェブサイト | `https://weechat.org/` | $download | WeeChat ウェブサイトのダウンロードページ | `https://weechat.org/download` | $time | 現在の日時 | `Sun, 16 Dec 2012 10:40:48 +0100` | $username | IRC サーバのユーザネーム | `ログイン名` | $realname | IRC サーバのリアルネーム | `John Doe` |=== [NOTE] ^(1)^ git バージョンとは `git describe` コマンドの出力です。git リポジトリで WeeChat をコンパイルし、git がインストールされている場合のみ値が設定されます。 CTCP オプションが設定されていない (デフォルトの) 場合、CTCP 応答は以下のようになります: [width="100%",cols="^2,4,8",options="header"] |=== | CTCP | 応答フォーマット | 例 | CLIENTINFO | `$clientinfo` | `ACTION DCC CLIENTINFO FINGER PING SOURCE TIME USERINFO VERSION` | FINGER | `WeeChat $versiongit` | `WeeChat 0.4.0-dev (git: v0.3.9-104-g7eb5cc4)` | SOURCE | `$download` | `https://weechat.org/download` | TIME | `$time` | `Sun, 16 Dec 2012 10:40:48 +0100` | USERINFO | `$username ($realname)` | `ログイン名 (John Doe)` | VERSION | `WeeChat $versiongit ($compilation)` | `WeeChat 0.4.0-dev (git: v0.3.9-104-g7eb5cc4) (Dec 16 2012)` |=== [[irc_target_buffer]] ==== IRC メッセージのターゲットバッファ `irc.msgbuffer.*` オプションを使えば、IRC メッセージに対するターゲットバッファ (メッセージを表示するバッファ) をカスタマイズすることができます。 一部の IRC メッセージ (以下のリストを参照) に対して、以下の値を設定できます: current:: 現在のバッファ (IRC バッファまたはサーババッファの場合のデフォルト) private:: ニックネームに対するプライベートバッファ、見つからない場合は現在のバッファまたはサーババッファ ('irc.look.msgbuffer_fallback' オプションに依存) server:: サーババッファ weechat:: WeeChat "core" バッファ オプションが設定されていない (デフォルトの) 場合、WeeChat は適当なバッファを選びます。通常ではサーバまたはチャンネルバッファです。 カスタマイズできる一部の IRC メッセージ、別名のリストは以下です: [width="60%",cols="^1m,^3m,8",options="header"] |=== | メッセージ | 別名 | 説明 | error | | エラー | invite | | チャンネルへの招待 | join | | 参加 | kick | | キック | kill | | キル | mode | | モード | notice | | notice | part | | 退出 | quit | | 終了 | topic | | トピック | wallops | | IRC オペレータメッセージ | | ctcp | ctcp (プライベートまたは notice メッセージ内の、送信または受信メッセージ) | 221 | | ユーザモード文字列 | 275 | whois | whois (セキュアな接続) | 301 | whois | whois (離席状態) | 303 | | サーバへの接続状態 | 305 | unaway | 着席状態 | 306 | away | 離席状態 | 307 | whois | whois (登録済みニックネーム) | 310 | whois | whois (ヘルプモード) | 311 | whois | whois (ユーザ) | 312 | whois | whois (サーバ) | 313 | whois | whois (オペレータ) | 314 | whowas | whowas | 315 | who | who (終了) | 317 | whois | whois (アイドル状態) | 318 | whois | whois (終了) | 319 | whois | whois (チャンネル) | 320 | whois | whois (身元確認済みユーザ) | 321 | list | list (開始) | 322 | list | list (チャンネル) | 323 | list | list (終了) | 326 | whois | whois (オペレータ権限を持っているユーザ) | 327 | whois | whois (ホスト) | 328 | | チャンネルの URL | 329 | | チャンネル作成日時 | 330 | whois | whois (ログイン時の名前) | 331 | | トピックが未設定のチャンネル | 332 | | チャンネルのトピック | 333 | | トピックに関する情報 | 335 | whois | whois (ボットが有効化されているか) | 338 | whois | whois (ホスト) | 341 | | 招待中 | 343 | whois | whois (オペレータ) | 344 | reop | チャンネルオペレータを復活 | 345 | reop | チャンネルオペレータを復活 (終了) | 346 | invitelist | 招待リスト | 347 | invitelist | 招待リスト (終了) | 348 | exceptionlist | 除外リスト | 349 | exceptionlist | 除外リスト (終了) | 351 | | サーババージョン | 352 | who | who | 353 | names | チャンネル内ユーザのリスト | 366 | names | チャンネル内ユーザのリストの終了 | 367 | banlist | 禁止リスト | 368 | banlist | 禁止リストの終了 | 369 | whowas | whowas (終了) | 378 | whois | whois (接続元) | 379 | whois | whois (モード) | 401 | whois | 指定したニックネームおよびチャンネルがありません | 402 | whois | 指定したサーバがありません | 432 | | erroneous ニックネーム | 433 | | ニックネームが使用されています | 438 | | ニックネームを変更する権限がありません | 671 | whois | whois (セキュアな接続) | 728 | quietlist | 発言禁止リスト | 729 | quietlist | 発言禁止リストの終了 | 732 | monitor | 監視中のニックネームのリスト | 733 | monitor | 監視中のニックネームのリスト (終了) | 901 | | ログインに成功 |=== その他の数値コマンドも同様にカスタマイズできます。 サーバ名を前につけることで、特定のサーバに対して設定することができます (例: `freenode.whois`)。 例: * `/whois` の結果をプライベートバッファに表示: ---- /set irc.msgbuffer.whois private ---- * whois に対する設定をデフォルトに戻す (サーババッファに表示): ---- /unset irc.msgbuffer.whois ---- * "freenode" サーバの場合、招待メッセージを現在のバッファに表示: ---- /set irc.msgbuffer.freenode.invite current ---- * "303" (ison) メッセージを WeeChat "core" バッファに表示: ---- /set irc.msgbuffer.303 weechat ---- [[logger_plugin]] === Logger プラグイン Logger プラグインを使うことで、バッファの内容をファイルに保存できます。 保存形式とその方法をオプションで設定できます。 [[logger_options]] ==== オプション (logger.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | look | /set logger.look.* | 外観 | color | /set logger.color.* | 色 | file | /set logger.file.* | ログファイルのオプション | level | /set logger.level.* | バッファのログレベル (オプションをセクションに追加/削除出来ます) | mask | /set logger.mask.* | バッファのファイル名マスク (オプションをセクションに追加/削除出来ます) |=== オプション: include::autogen/user/logger_options.asciidoc[] [[logger_commands]] ==== コマンド include::autogen/user/logger_commands.asciidoc[] [[logger_log_levels]] ==== ログレベル ログ保存はそれぞれのバッファに対して設定されたログレベルに従って行われます。デフォルトのレベルは 9 (バッファに表示されたメッセージをすべて保存) です。 特定のバッファやバッファグループに対して個別にログレベルを設定できます。 設定可能なレベルは 0 から 9 です。0 は "保存しない"、9 は "すべてのメッセージを保存" を意味します。 それぞれのプラグインでレベルの意味が変わります。 IRC プラグインに対しては以下のレベルが利用されます: * レベル 1: ユーザからのメッセージ (チャンネルまたはプライベート) * レベル 2: ニックネームの変更 (自身と他のユーザ) * レベル 3: 任意のサーバメッセージ (参加/退出/終了メッセージを除く) * レベル 4: 参加/退出/終了メッセージ 従って、IRC チャンネルに対してレベル 3 を設定した場合、WeeChat は参加/退出/終了メッセージを除いて全てのメッセージを保存します。 例: * IRC チャンネル #weechat に対してレベル 3 を設定: ---- /set logger.level.irc.freenode.#weechat 3 ---- * freenode サーババッファに対してレベル 3 を設定: ---- /set logger.level.irc.server.freenode 3 ---- * freenode サーバの全てのチャンネルに対してレベル 3 を設定: ---- /set logger.level.irc.freenode 3 ---- * 全ての IRC バッファに対してレベル 2 を設定: ---- /set logger.level.irc 2 ---- [[logger_filenames_masks]] ==== ファイル名マスク バッファに対し個別にファイル名マスクを設定することができます、 ファイル名にはローカルバッファ変数が利用されます。現在のバッファに設定されたローカル変数を確認するには: ---- /buffer localvar ---- 例えば "irc.freenode.#weechat" バッファの場合、WeeChat は以下の順番でオプションに設定されたファイル名マスクを検索します: ---- logger.mask.irc.freenode.#weechat logger.mask.irc.freenode logger.mask.irc logger.file.mask ---- 特定の IRC サーバ ("logger.mask.irc.freenode") またはプラグイン ("logger.mask.irc") のグループに対して共通のマスクを適用できます。 [[logger_files_by_date]] ===== ログファイルに日付を利用する ログファイルに日付を使うには、マスクに日時/時間指定子を利用できます (フォーマットに関しては `man strftime` を参照してください)。例えば: ---- /set logger.file.mask "%Y/%m/$plugin.$name.weechatlog" ---- 以下のファイルが作成されます: .... ~/.weechat/ |--- logs/ |--- 2010/ |--- 11/ | irc.server.freenode.weechatlog | irc.freenode.#weechat.weechatlog |--- 2010/ |--- 12/ | irc.server.freenode.weechatlog | irc.freenode.#weechat.weechatlog .... [[logger_irc_files_by_server_channel]] ===== IRC ログファイルにサーバとチャンネル名を利用する IRC サーバ名を使ったディレクトリに、チャンネル名を使ったファイルを作成する場合: ---- /set logger.mask.irc "irc/$server/$channel.weechatlog" ---- 以下のファイルが作成されます: .... ~/.weechat/ |--- logs/ |--- irc/ |--- freenode/ | freenode.weechatlog | #weechat.weechatlog | #mychan.weechatlog |--- oftc/ | oftc.weechatlog | #chan1.weechatlog | #chan2.weechatlog .... [[relay_plugin]] === Relay プラグイン Relay プラグインはネットワークを介して異なるプロトコルを用いてデータを中継するために利用します: * 'irc': IRC プロキシ: IRC サーバに対する接続を、単一または複数の IRC クライアントで共有するために用います。 * 'weechat': WeeChat の表示にリモートインターフェイス (例えば QWeeChat) を使う場合に利用されるプロトコル [[relay_options]] ==== オプション (relay.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | look | /set relay.look.* | 外観 | color | /set relay.color.* | 色 | network | /set relay.network.* | ネットワークオプション | irc | /set relay.irc.* | 特定の irc プロトコルのオプション (irc プロキシ) | port | <> + /set relay.port.* | リレーに使うポート(irc や weechat プロトコル) (オプションをセクションに追加/削除出来ます) |=== オプション: include::autogen/user/relay_options.asciidoc[] [[relay_commands]] ==== コマンド include::autogen/user/relay_commands.asciidoc[] [[relay_password]] ==== パスワード 以下のコマンドを利用して、リレー用のパスワードを設定することを強くお勧めします: ---- /set relay.network.password "mypass" ---- このパスワードは 'irc' と 'weechat' プロトコルで利用されます。 [[relay_ssl]] ==== SSL 証明書と秘密鍵を作り、プロトコル名の最初に "ssl." を付けることで SSL 経由でリレーを利用することができます。 証明書/秘密鍵ファイルへのデフォルトパスは '~/.weechat/ssl/relay.pem' です (option <>)。 以下のコマンドを使って証明書と秘密鍵ファイルを作成します: ---- $ mkdir -p ~/.weechat/ssl $ cd ~/.weechat/ssl $ openssl req -nodes -newkey rsa:2048 -keyout relay.pem -x509 -days 365 -out relay.pem ---- WeeChat が既に起動している場合、 以下のコマンドで証明書と秘密鍵を再読み込みできます: ---- /relay sslcertkey ---- [[relay_irc_proxy]] ==== IRC プロキシ Relay プラグインは IRC プロキシとしても使えます: Relay プラグインは IRC サーバのふりをして、他の IRC クライアント (WeeChat 自身も) は WeeChat に接続できます。 IRC サーバごとに異なるポート、もしくは全てのサーバに対して共通のポートを定義することができます。 すべてのサーバに対して共通のポートを定義した場合には、クライアントからサーバの内部名を IRC の "PASS" コマンドに含めて送信するようにしてください、以下のフォーマットを使ってください: ---- PASS server:mypass ---- 例: SSL を使い、全てのサーバに対して共通の IRC プロキシを設定 (サーバはクライアントが選択): ---- /relay add ssl.irc 8000 ---- 例: SSL を使わず、内部名 "freenode" のサーバに対して IRC プロキシを設定: ---- /relay add irc.freenode 8000 ---- 任意の IRC クライアントからサーバパスワード "mypass" (全てのサーバに対して共通の IRC プロキシを設定した場合には "freenode:mypass") で 8000 番ポートに接続出来ます。 [[relay_weechat_protocol]] ==== WeeChat プロトコル Relay プラグインは WeeChat プロトコルを使ってリモートインターフェイスに対してデータを送信できます。 リモートインターフェイスを使って接続できます、ダウンロードページのリストを御覧ください: https://weechat.org/download [IMPORTANT] このプロトコルを使った場合 WeeChat から他の WeeChat に接続することはできません。 例: ---- /relay add weechat 9000 ---- この後、リモートインターフェイスを使って 9000 番ポートに対して、パスワード "mypass" で接続することができます。 [[relay_websocket]] ==== WebSocket Relay プラグインはすべてのプロトコルに対して WebSocket プロトコル (http://tools.ietf.org/html/rfc6455[RFC 6455]) をサポートします。 WebSocket ハンドシェイクは自動的に検知され、ハンドシェイク中に必要なヘッダが見つかり origin が許可されていれば WebSocket 用のソケットが準備されます (オプション <> を参照)。 HTML5 を使えばたった 1 行の JavaScript で WebSocket をオープンすることが可能です: [source,js] ---- websocket = new WebSocket("ws://server.com:9000/weechat"); ---- ポート番号 (例では 9000 番) は Relay プラグインで定義したものです。URI の最後には必ず "/weechat" をつけます ('irc' と 'weechat' プロトコルの場合)。 [[scripts_plugins]] === スクリプトプラグイン WeeChat は 7 種類のスクリプトプラグインを備えています: Python、Perl、Ruby、Lua、Tcl、Guile (scheme)、Javascript。 これらのプラグインでそれぞれの言語で書かれたスクリプトのロード、実行、アンロードができます。 "スクリプト" と呼ばれるほかのプラグインはスクリプトマネージャで、任意の言語で書かれたスクリプトをロード / アンロードしたり、WeeChat スクリプトリポジトリ (https://weechat.org/scripts から参照可能) のスクリプトをインストール / 削除するために利用します。 スクリプトの書き方やスクリプト用の WeeChat API についての詳しい情報は、 'WeeChat スクリプト製作ガイド' を参照してください。 [[script_options]] ==== スクリプトオプション (script.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | look | /set script.look.* | 外観 | color | /set script.color.* | 色 | scripts | /set script.scripts.* | スクリプトのダウンロードに関するオプション |=== オプション: include::autogen/user/script_options.asciidoc[] [[script_commands]] ==== Script コマンド include::autogen/user/script_commands.asciidoc[] [[python_commands]] ==== Python コマンド include::autogen/user/python_commands.asciidoc[] [[perl_commands]] ==== Perl コマンド include::autogen/user/perl_commands.asciidoc[] [[ruby_commands]] ==== Ruby コマンド include::autogen/user/ruby_commands.asciidoc[] [[lua_commands]] ==== Lua コマンド include::autogen/user/lua_commands.asciidoc[] [[tcl_commands]] ==== Tcl コマンド include::autogen/user/tcl_commands.asciidoc[] [[guile_commands]] ==== Guile コマンド include::autogen/user/guile_commands.asciidoc[] [[javascript_commands]] ==== Javascript コマンド include::autogen/user/javascript_commands.asciidoc[] [[trigger_plugin]] === トリガプラグイン トリガは WeeChat の便利ツールです: 様々なもの (signal、modifier、print、...) をフックして、データの内容を書き換えたり、複数のコマンドを実行することができます。条件をつけることで一部の場合だけトリガを実行するように設定することもできます。 トリガを使うにはシグナル、修飾子、... がどのように動いているかを知らなければいけません。これを知るには 'WeeChat プラグイン API リファレンス' の 'フック' の章を読むことをお勧めします。 [[trigger_options]] ==== オプション (trigger.conf) セクション: [width="100%",cols="3m,6m,16",options="header"] |=== | セクション | 操作コマンド | 説明 | look | /set trigger.look.* | 外観 | color | /set trigger.color.* | 色 | trigger | <> + <> + /set trigger.trigger.* | トリガオプション |=== オプション: include::autogen/user/trigger_options.asciidoc[] [[trigger_commands]] ==== コマンド include::autogen/user/trigger_commands.asciidoc[] [[trigger_anatomy]] ==== トリガの構造 トリガは以下のオプションをとります (名前は `trigger.trigger..