Skip to content

taro-yamada/JDim

 
 

Repository files navigation

JDim - 2ch browser for linux

ここに書かれていない詳細についてはリポジトリを参照してください。

概要

JDim (JD improved) は gtkmm/GTK+ を使用した"2ちゃんねる"型マルチスレッドBBSを閲覧するためのブラウザです。 JDim は GPLv2 の下で公開されている JD からforkしたソフトウェアであり、 ルック・アンド・フィールや環境設定は JD と互換性があります。

注意: JDim本体は5ch.netのAPIに対応しておりません。 ご不便をおかけして申し訳ありませんが、5ch.netにアクセスする場合はWebブラウザなどをご使用ください。

動作プラットフォーム

LinuxなどのUnixライクなOS(FreeBSD,OpenBSD,Nexenta,MacOSXでも動作報告例があります)。 WindowsではMinGWを使ってビルド可能ですが、動作はまだ安定していないようです。

導入方法

ソースコードからJDimをビルドします。デフォルトの設定ではGTK2版がビルドされますのでご注意ください。 詳細は INSTALL にも書いてあります。

事前準備

ツールチェーンとライブラリをインストールします。一度インストールすれば次回から事前準備はいりません。

Redhat系

GTK2版

dnf install gtkmm24-devel gnutls-devel libgcrypt-devel libSM-devel libtool automake autoconf-archive git

GTK3版 - gtkmm24-devel のかわりに gtkmm30-devel をインストールします。

dnf install gtkmm30-devel gnutls-devel libgcrypt-devel libSM-devel libtool automake autoconf-archive git

Debian (stretch-backportsあるいはbuster以降)

sudo apt install libc6-dev make gcc g++ git
sudo vi /etc/apt/sources.list
# ↑エディタは何でも良い。deb-src行でstretch-backportsあるいはbuster以降を有効にする
sudo apt update
sudo apt build-dep jdim

Ubuntu 18.04

開発環境が入っていない場合は、

sudo apt-get install build-essential automake autoconf-archive git libtool

必要なライブラリを入れます。(抜けがあるかも)

GTK2版

sudo apt-get install libgtkmm-2.4-dev libmigemo1 libasound2-data libltdl-dev libasound2-dev libgnutls28-dev libgcrypt20-dev

GTK3版 - libgtkmm-2.4-dev のかわりに libgtkmm-3.0-dev をインストールします。

sudo apt-get install libgtkmm-3.0-dev libmigemo1 libasound2-data libltdl-dev libasound2-dev libgnutls28-dev libgcrypt20-dev

ビルド

GTK2版 (デフォルト)

git clone -b master --depth 1 https://github.com/JDimproved/JDim.git jdim
cd jdim
autoreconf -i
./configure
make

GTK3版 - ./configure にオプション --with-gtkmm3 を追加します。

git clone -b master --depth 1 https://github.com/JDimproved/JDim.git jdim
cd jdim
autoreconf -i
./configure --with-gtkmm3
make

実行するには直接 src/jdim を起動するか手動で /usr/bin あたりに src/jdim を cp します。

Arch Linux

GTK3版のビルドファイルはAURで公開されています。(Thanks to @naniwaKun.)
https://aur.archlinux.org/packages/jdim-git/

AUR Helper yay でインストール

yay -S jdim-git

参考

詳しいインストールの方法は 本家のwiki を参照してください。

Tips

  • buildの高速化

    make するときに -j job数(並列処理の数) を指定すれば高速にコンパイルできます。 使用するCPUのコア数と相談して決めてください。

  • ‘to_string’ is not a member of ‘std’なエラーが出た場合

    このエラーが出た場合は、 automake のマクロが入っていないか、gcc のバージョンが古い可能性があります。 automakeのマクロはubuntuでは autoconf-archive というパッケージ名です。

    またマクロを入れなくても、

    make CXXFLAGS+="-std=c++11"

    でも同様の効果があります。もしこれで駄目な場合はgccのversionが古すぎるので、 gccのバージョンアップをするか、ディストリをバージョンアップしてください。

  • configureチェック中に AX_CXX_COMPILE_STDCXX_11(noext, mandatory) に関連したエラーがでた場合

    ubuntuでは autoconf-archive をインストールして autoreconf -i からやり直してみてください。 パッケージが見つからないまたはエラーが消えない場合は以下の手順を試してみてください。

    1. configure.acAX_CXX_COMPILE_STDCXX_11([noext], [mandatory]) の行を削除する。
    2. autoreconf -iconfigure を作りconfigureチェックをやり直す。
    3. make CXXFLAGS+="-std=c++11" でビルドする。

GTK3版について

GTK3版はGTK2版同様のルック・アンド・フィールになるように実装していますが、 技術的な問題やテスト不足から完全な再現はできていません。 もしお気づきの点などがございましたらご指摘いただけると幸いです。

マウスホイール操作

板一覧やスレ一覧でマウスホイールによるスクロールが動作しないことがあります。 環境変数 GDK_CORE_DEVICE_EVENTS=1 を設定してjdimを起動するとマウスホイール機能が使えます。

# シェルからJDimを起動する場合
GDK_CORE_DEVICE_EVENTS=1 ./src/jdim

GTK2版から変更/追加された部分

  • 書き込みビューの配色にGTKテーマを使う設定が追加された。
    1. メニューバーの設定(C) > フォントと色(F) > 詳細設定(R)...からフォントと色の詳細設定を開く
    2. 色の設定タブにある書き込みビューの配色設定に GTKテーマ を用いる(W)をチェックして適用する

GTK3版の既知の問題

  • マウスホイールでタブを切り替える機能が動作しない環境がある。(gtk 3.20以上?)
  • タブのドラッグ・アンド・ドロップの矢印ポップアップの背景が透過しない環境がある。 (アルファチャンネルが利用できない環境)

通常の起動

使い方は以下のとおりです。

$ jdim [OPTION] [URL,FILE]

引数にURLを付けて起動する事も出来るので、他のアプリケーションから外部コマンドとしてURLを開く事などが出来ます。 (JDimが扱う事の出来るURLでない場合は設定されているWebブラウザに渡されます)

$ jdim http://pc99.2ch.net/test/read.cgi/linux/1234567890/

ローカルにあるdatファイルを指定して、一時的にスレビュー表示させることも出来ます。

$ jdim ./12345.dat

環境変数 JDIM_CACHE でキャッシュディレクトリの位置を変更・指定することが可能です。 指定しなければ ~/.jd がキャッシュディレクトリになります。

$ JDIM_CACHE=~/.mycache jdim

環境変数 JDIM_LOCK でロックファイルの位置を変更・指定することが可能です。 指定しなければ ~/.jd/JDLOCK がロックファイルになります。

$ JDIM_LOCK=~/mylock jdim

コマンドライン オプション

オプション 説明
-h, --help ヘルプを表示
-m, --multi 多重起動時のサブプロセスであっても終了しない
-n, --norestore 前回異常終了した時にバックアップファイルを復元しない
-s, --skip-setup 初回起動時の設定ダイアログを表示しない
-l, --logfile エラーなどのメッセージをファイル(キャッシュディレクトリのlog/msglog)に出力する
-g, --geometry WxH-X+Y 幅(W)高さ(H)横位置(X)縦位置(Y)の指定。WxHは省略化(例: -g 100x40-10+30, -g -20+100 )
-V, --version バージョン及びconfigureオプションを全て表示

多重起動について

JDimはメインプロセス/サブプロセスという関係で動作します。

  • メインプロセス: 指令を受け取る事が出来るプロセス
  • サブプロセス: 指令を出す事が出来るプロセス

通常は最初に起動した物がメインプロセスとなり、メインプロセスは1つだけ存在する事が出来ます。 メインプロセスが存在する状態で起動したプロセスはサブプロセスとして扱われ、複数存在させる事も可能です。 なお、指令を受け取るのはメインプロセスのみなので、指令を出す側のサブプロセスでURLは開かれません。

以下のコマンドを使い分ける事でサブプロセスの起動のしかたをコントロール出来ます。

  • a. 起動するかどうか確認してサブプロセスを起動
    $ jdim
  • b. 確認せずにサブプロセスを起動
    $ jdim -m
  • c. メインプロセスにURLを渡してサブプロセスを起動
    $ jdim -m http://pc99.2ch.net/test/read.cgi/linux/1234567890/

注: サブプロセスを残したままメインプロセスを終了していた場合は次に起動したプロセスがメインプロセスとなります。

JDとの互換性

JDimの環境設定はJDからフォーマットを継承しているので後方互換性があります。 また、ユーザーインタフェースの変更は今のところありません。 JDimで追加された不具合や機能の修正についてはPull requestsを見てください。

JDから移行する

  • デフォルトのキャッシュディレクトリ(~/.jd)を使用している場合はデータや設定をそのままJDimで使うことができます。
  • 環境変数JD_CACHEでキャッシュディレクトリを設定している場合はかわりにJDIM_CACHEを使用してください。
  • JDとJDimを併存させる(データや設定を共有しない)ためには環境変数によるキャッシュディレクトリの設定が必要です。 (通常の起動を参照)

著作権

© 2017-2019 yama-natuki [https://github.com/yama-natuki/JD]
© 2019 JDimproved project [https://github.com/JDimproved/JDim]

パッチやファイルを取り込んだ場合、それらのコピーライトは「JDimproved project」に統一します。

fork元の JD:

© 2006-2015 JD project [https://ja.osdn.net/projects/jd4linux/]

ライセンス

JDim は GPLv2 の下で公開されています。 GNU General Public License, version 2

連絡先

バグ報告その他は Linux板@5ちゃんねる のJD/JDimスレ、 またはJDimのリポジトリにて行ってください。

About

5ch browser for linux

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 98.7%
  • Other 1.3%