Ruby/EB 拡張ライブラリ

for version 2.5

目次

概要

EPWING/EBなどのCD-ROM 書籍にアクセスするための関数を集めた、C 言語のライブラリ 「EB」 をrubyから利用するための拡張ライブラリです。EBについて詳しくは配布元である こちら のページへどうぞ。EBの作者はMotoyuki Kasahara様です。

利用には当然EBが正しくインストールされている必要があります。
Ruby/EB version2より、EBの3.2以降を要求します。 また、Ruby/EBの1.xに対してテキストフック関係の仕様が変更されています。ご注意下さい。

EBが漢字コードとしてEUCを要求しますので、$KCODEはEUCでお願いします。

EB自身がGPLのため、本Ruby拡張ライブラリもGPLとします。

実はこの文章は こちら の笠原様の文章のパクリの部分が多々あります。どうもすみません。

Book#search2系、Book#content,フック関連、Positionクラスなどは黒田様からのパッチに拠るところが大きいです。どうもありがとうございました。

EBの3.0alphaへの対応は新改様のコーディングに依るものです。どうもありがとうございました。

EB3.0+への対応は、やまだ様、うえち様両名よりパッチを頂きました。どうもありがとうございました。

EB-3.2.1への対応は、高宗様、knu様作成のパッチによります。どうもありがとうございました。

いいかげんだったAppendixへの対応は、山田様によって修正されました。どうもありがとうございます。

EB-4.0を利用する場合は、EB-4.0本体にパッチが必要です。

RubyEB 2.2より、かずひこ氏が開発に参加されました。

取得

RubyEBのページから取得して頂けます。
また、cvsから取得すると、一番新しいものが手に入ったりするかもしれません。しかし大々的な不具合が混入中の可能性もあります。
方法

文中の最大ブロック長はデフォルトでは65530bytesです。

module EB

errorcode
ebでエラーが発生したときセットされます。
error_message
errorcodeを文字列にしたものを返します

EB::Book

クラスメソッド

new

メソッド(書籍)

bind
オブジェクトを、パス path にある CD-ROM 書籍に結び付けます。パスは書籍のトップディレクトリ、つまり `CATALOG' か `CATALOGS' ファイルのあるディレクトリでなくてはなりません。
suspend
オブジェクトが現在選択中のもの、すなわち、選択中の副本、言語、フォントの高さをすべて未選択にします
bound?
書籍に結び付いているかどうかを調べます。
disctype
ディスクの形式を返します。 オブジェクトはあらかじめ書籍に結び付いていなければなりません。
path
書籍のパスを返します。 オブジェクトはあらかじめ書籍に結び付いていなければなりません。
charcode
書かれている文字コードを返します。 オブジェクトはあらかじめ書籍に結び付いていなければなりません。
subbook_count
オブジェクト内の副本の数を返します。オブジェクトは、あらかじめ書籍に結び付けられていなくてはなりません。
subbook_list
副本のリストを作成して副本コードの配列として返します。ここで得られる副本コードを用いて、set(subbook)/title/directoryメソッドにおいて副本を指定します。
set(subbook) : alias subbook=
副本を選択します。
subbook
現在選択中の副本の副本コードを返します。あらかじめ、オブジェクト内のいずれかの副本が選択されていなくてはなりません。 設定されていない場合は-1となります。
unset
副本の選択を解除します。
hookset/hooset=
テキストフックのセットを取得・設定します。設定する場合はEB::Hooksetのインスタンスかnilしか出来ません。nilを設定したときはフックを解除します。
appendix_path=
Appendixを設定します。

メソッド(副本)

title(subbook=currently)
現在選択中の副本の題名を返します。あらかじめ、オブジェクト内のいずれかの副本が選択されていなくてはなりません。
引数を省略すると、現在選択されている副本の題名を返します。
directory(subbook=currently)
現在選択中の副本のディレクトリ名を返します。あらかじめ、オブジェクト内内のいずれかの副本が選択されていなくてはなりません。
引数を省略すると、現在選択されている副本のディレクトリを返します。
search_available?
現在選択中の副本が前方一致検索メソッドを持っているかどうか調べます。
副本が選択されていない場合はRuntimeErrorをraiseします。
exactsearch_available?
現在選択中の副本が完全一致検索メソッドを持っているかどうか調べます。
副本が選択されていない場合はRuntimeErrorをraiseします。
endsearch_available?
現在選択中の副本が後方一致検索メソッドを持っているかどうか調べます。
副本が選択されていない場合はRuntimeErrorをraiseします。
keywordsearch_available?
現在選択中の副本がキーワード検索メソッドを持っているかどうか調べます。
副本が選択されていない場合はRuntimeErrorをraiseします。
menu_available?
メニューが利用できるかどうかを調べます。
副本が選択されていない場合などでRuntimeErrorをraiseします。
copyright_available?
著作権表示が利用できるかどうかを調べます。
copyright
著作権表示を返します。

メソッド(検索)

search(word,max=all)
wordをキーとして前方一致検索を行い、結果を配列に入れて返します。配列の各要素は[ heading, text ]として与えられます。
イテレータとして用いると、[heading,text]の配列をyieldします。返り値としてEB::Cancelを与えると、イテレートを終了します。(breakで抜けても良いです)
exactsearch(word,max=all)
wordをキーとして完全一致検索を行い、結果を配列に入れて返します。配列の各要素は[ heading, text ]として与えられます。
イテレータとして用いると、[heading,text]の配列をyieldします。返り値としてEB::Cancelを与えると、イテレートを終了します。(breakで抜けても良いです)
endsearch(word,max=all)
wordをキーとして後方一致検索を行い、結果を配列に入れて返します。配列の各要素は[ heading, text ]として与えられます。
イテレータとして用いると、[heading,text]の配列をyieldします。返り値としてEB::Cancelを与えると、イテレートを終了します。(breakで抜けても良いです)
keywordsearch(words,max=all)
wordsはキーワードの配列とし、キーワードによる検索を行います。それ以外は上記検索メソッドと同じ。
search2(word,max=all)
exactsearch2(word,max=all)
endsearch2(word,max=all)
この3つはそれぞれ、search/exactsearch/endsearchと同じですが、配列に入れたりyieldするものが異なります。
イテレータとして用いると、[結果のEB::Positionインスタンス,検索語]をyieldします。そうでない場合は、同じ物を配列に入れて返します。
keywordsearch2(words,max=all)
wordsはキーワードの配列とし、キーワードによる検索を行います。それ以外は上記検索メソッドと同じ。
menu
トップメニューの内容を返します。各メニュー項目の参照先はテキストフックのCANDIDATEやREFERENCEとして渡されます。
menu2
トップメニューの書籍上の位置をEB::Positionのインスタンスで返します。
content(position)
positionはEB::Positionのインスタンスです。
positionで示される位置の本文の内容を返します。最大ブロック長まで読み込みます。
イテレータとして用いると最大ブロック長のブロックをyieldしながら本文の区切りが来るまで読み込みます。
content_noseek
シーク動作を行わずに本文の内容を読みとり返します。最大ブロック長だけ読み込みます。このメソッドを読む前にはcontent()などでシークを行っておく必要があります。

メソッド(副本:外字・フォント)

fontcode_list
利用可能なフォントの一覧(配列)を返します。中身はintegerですが、それぞれEB::FONT_**の定数に対応します。FONT_16,FONT_24,FONT_30,FONT_48がそれぞれ0,1,2,3です。
fontcode/fontcode=
フォントの大きさを取得・指定します。EB::FONT_**の定数を与えます。取得する外字フォントのサイズに影響します。fontcode未設定の場合はEB::FONT_INVALID(-1)となります。
get_widefont(code)
codeで示される全角外字フォントを得ます。返値はEB::ExtFontのインスタンスです。
get_narrowfont
codeで示される半角外字フォントを得ます。返値はEB::ExtFontのインスタンスです。
wide_startcode
選択中の副本における全角外字の先頭コードを返します。
wide_endcode
選択中の副本における全角外字の終了コードを返します。
narrow_startcode
選択中の副本における半角外字の先頭コードを返します。
narrow_endcode
選択中の副本における半角外字の終了コードを返します。

メソッド(マルチメディアデータ)

read_monographic(pos,width,height)
モノクロ図版のデータを取得し、Stringとして返します。
posはEB::Positionのインスタンスで読み込み位置を示します。また、widthとheightで読み込まれるべき図版のサイズを指定します。サイズや位置はテキストフックの引数として得られます。
read_colorgraphic(pos,stoplength=最大ブロック長)
read_colorgraphic(pos,stoplength=最大ブロック長){|block| proc}
カラーの図版を取得し、Stringとして返します。(最大stoplengthバイトまで)
イテレータとして用いるとstoplengthバイトを読み出してblockとして与え、終わるまで繰り返します。その場合、メソッドの返値は読み込み長を返します。
posはEB::Positionのインスタンスで読み込み位置を示します。また、stoplengthで読み込みバイト数を指定します。stoplengthは読み込むバイト数の上限です。電子ブックではEBライブラリに「データ終了位置が来ても読み込みをやめない」という制限事項があります。(BMPやJPEGのデコードを本ライブラリで行い、適当に止めれれば良いのですが)
read_wavedata(startpos,endpos,stoplength=最大ブロック長)
音声データをStringとして取得します。(最大stoplengthバイトまで)
イテレータとして用いるとstoplengthバイトを読み出してblockとして与え、終わるまで繰り返します。その場合、メソッドの返値は読み込み長を返します。
startposは開始位置、endposは終了位置を示す、EB::Positionのインスタンスです。これらはテキストフックから情報が得られます。
read_mpeg(code1,code2,code3,code4,stoplength=最大ブロック長)
動画データをStringとして取得します。(最大stoplengthバイトまで)
イテレータとして用いるとstoplengthバイトを読み出してblockとして与え、終わるまで繰り返します。その場合、メソッドの返値は読み込み長を返します。
code1かcode4までは、HOOK_BEGIN_MPEGのargv[2]からargv[5]に相当します。
compose_mpegfilename(code1,code2,code3,code4)
code1からcode4で示される動画のファイル名を取得します。

EB::Position

クラスメソッド

new(page,offset)
ページとオフセットからEB_Positionを設定します。

属性

読み書き可能です。
page
offset

EB::ExtFont

外字を表します。インスタンスはEB::Book#get_widefontもしくはEB::Bookget_narrowfontで取得します。
widefont?
外字が全角であればtrueを返します。
code
外字のコードを返します。
to_xbm
外字のビットマップデータをxbm形式のStringで返します。
to_xpm
外字のビットマップデータをxpm形式のStringで返します。
to_gif
外字のビットマップデータをgif形式のStringで返します。
ファイルに落とせばそのままgifファイルになります。
to_bmp
外字のビットマップデータをbmp形式のStringで返します。
ファイルに落とせばそのままbmpファイル(Windows・OS/2)になります。
to_png
外字のビットマップデータをpng形式のStringで返します。
ファイルに落とせばそのままpngファイルになります。

EB::Hookset

クラスメソッド

new
Hooksetのインスタンスを作成します。これはテキストフックを扱います。

メソッド

register(hook,proc)
register(hook){|eb,argv| proc }
hookはフックの種類を示す定数です。
ebは呼び出し元のEB::Bookであり、argvはテキストフックの引数の配列です。
イベント発生時に呼ばれるメソッドを設定します。hookに与える定数は、EB::の下に定数として定義されています(EB::HOOK_****)。"EB::定数"の項参照。
また、返値がnil以外の場合はテキストに返値を書き込みます。(String以外の場合はObject#to_strします)
同じフックに対して複数回設定を行うと、最後に行った設定のみ有効です。

EB::定数

Ruby EB のバージョンは以下の定数で定義されています。 また、eb-3.2以降では以下の定数が定義されています。eb.cの最後の方と、EB Libraryのリファレンスを参照して下さい。


#!/bin/env ruby -Ke
require "eb"

b=EB::Book.new
b.bind("/cdrom")
b.subbook=0
b.exactsearch( "じしょ" ) do |word,desc|
  print "====================¥n"
  print "==   ",word,"¥n"
  print "¥n",desc,"¥n"
#  EB::Cancel   # yield will be stopped
end

例2


require "eb"

b=EB::Book.new
b.bind("/cdrom")
b.subbook=0
b.exactsearch2( "じしょ" ) do |pos,word|
  print "====================¥n"
  print "==   ",word,"¥n"
  print "¥n",b.content(pos),"¥n"
#  EB::Cancel   # yield will be stopped
end

履歴


Email: nyasu3w@users.sourceforge.net