572件ヒット
[1-100件を表示]
(0.060秒)
クラス
-
Fiddle
:: CStruct (22) -
Fiddle
:: Closure (33) -
Fiddle
:: Function (55) -
Fiddle
:: Handle (77) -
Fiddle
:: Pointer (275)
モジュール
-
Fiddle
:: Importer (110)
キーワード
- + (11)
- +@ (11)
- - (11)
- -@ (11)
- <=> (11)
- == (11)
- [] (44)
- []= (22)
- abi (11)
- args (11)
- bind (11)
- call (11)
- close (11)
-
close
_ enabled? (11) -
create
_ value (11) - ctype (11)
-
disable
_ close (11) -
enable
_ close (11) - eql? (11)
- extern (11)
- free (11)
- free= (11)
-
import
_ symbol (11) - name (11)
- null? (11)
- ptr (22)
- ref (11)
- size (11)
- size= (11)
- sizeof (11)
- struct (11)
- sym (11)
-
to
_ i (55) -
to
_ int (11) -
to
_ ptr (11) -
to
_ s (22) -
to
_ str (22) -
to
_ value (11) - typealias (11)
- union (11)
- value (11)
検索結果
先頭5件
-
Fiddle
:: Pointer # to _ int -> Integer (6203.0) -
自身が指すアドレスを整数で返します。
自身が指すアドレスを整数で返します。 -
Fiddle
:: Function # name -> nil | String (6103.0) -
関数の名前を返します。
...関数の名前を返します。
名前が定義されていない場合は nil を返します。
@see Fiddle::Function.new... -
Fiddle
:: Handle # close _ enabled? -> bool (6103.0) -
GC によるオブジェクトの回収時に self をクローズする(Fiddle::Handle#close) かどうかを真偽値で返します。
...GC によるオブジェクトの回収時に self をクローズする(Fiddle::Handle#close)
かどうかを真偽値で返します。
@see Fiddle::Handle#enable_close, Fiddle::Handle#disable_close... -
Fiddle
:: Handle # enable _ close -> nil (6103.0) -
GC によるオブジェクトの回収時に self をクローズする(Fiddle::Handle#close) ように設定します。
...GC によるオブジェクトの回収時に self をクローズする(Fiddle::Handle#close)
ように設定します。
デフォルトでは close しません。
@see Fiddle::Handle#disable_close, Fiddle::Handle#close_enabled?... -
Fiddle
:: Pointer # null? -> bool (6103.0) -
自身が NULL なら true を返します。そうでないなら false を返します。
...自身が NULL なら true を返します。そうでないなら false を返します。... -
Fiddle
:: Importer # bind(signature , *opts) { . . . } -> Fiddle :: Function (6102.0) -
Ruby のブロックを C の関数で wrap し、その関数をモジュールに インポートします。
...ュール関数として定義されます。
また、Fiddle::Importer#[] で Fiddle::Function オブジェクトとして
取り出すことができます。
signature で関数の名前とシネグチャを指定します。例えば
"int compare(void*, void*)" のように指定します。......n インポートした関数を表す Fiddle::Function オブジェクトを返します。
@param signature 関数の名前とシネグチャ
@param opts オプション
例
require 'fiddle/import'
module M
extend Fiddle::Importer
dlload "libc.so.6"
typealias "size_t", "unsign......ed long"
extern "int qsort(void*, size_t, size_t, void*)"
bind("int compare(void*, void*)"){|px, py|
x = px.to_s(Fiddle::SIZEOF_INT).unpack("i!")
y = py.to_s(Fiddle::SIZEOF_INT).unpack("i!")
x <=> y
}
end
data = [32, 180001, -13, -1, 0, 49].pack("i!*")
M.... -
Fiddle
:: Importer # extern(signature , *opts) -> Fiddle :: Function (6102.0) -
Fiddle::Importer#dlload で取り込んだライブラリから C の関数をインポートします。
...
Fiddle::Importer#dlload で取り込んだライブラリから
C の関数をインポートします。
インポートした関数はそのモジュールにモジュール関数として定義されます。
signature で関数の名前とシネグチャを指定します。例えば
"int str......@return インポートした関数を表す Fiddle::Function オブジェクトを返します。
@param signature 関数の名前とシネグチャ
@param opts オプション
例
require 'fiddle/import'
module M
extern Fiddle::Importer
dlload "libc.so.6"
extern "int strcmp(......char*, char*)"
end
M.strcmp("abc", "abc") # => 0
M.strcmp("abc", "abd") # => -1... -
Fiddle
:: Importer # union(signature) -> Class (6102.0) -
C の共用体型に対応する Ruby のクラスを構築して返します。
...定義する方法は Fiddle::Importer#struct と
ほぼ同様です。C における
typedef union epoll_data
{
void *ptr;
int fd;
uint32_t u32;
uint64_t u64;
} epoll_data_t;
は、Ruby上では
require 'fiddle/import'
module M
extend Fiddle::Importer
dlload "li.......so.6"
typealias("uint32_t", "unsigned int")
typealias("uint64_t", "unsigned long long")
EPollData = union(["void *ptr",
"int fd",
"uint32_t u32",
"uint64_t u64",
])
end
となります。......返されるクラスは Fiddle::CUnion を継承しています。
1.9.x ではこのメソッドで返されるクラスは正しく動作しません。
2.0以降では修正されています。
@param signature 共用体の各要素を文字列で表現したものの配列... -
Fiddle
:: Pointer # +(n) -> Fiddle :: Pointer (3126.0) -
自身のアドレスに n バイトを足した新しい Pointer オブジェクトを返します。
...スに n バイトを足した新しい Pointer オブジェクトを返します。
この返り値には、free 関数がセットされず、size は 0 とされます。
@param n アドレスの増分を整数で指定します。
例:
require 'fiddle'
s = 'abc'
cptr = Fiddle::Pointer[s]... -
Fiddle
:: Pointer # -(n) -> Fiddle :: Pointer (3126.0) -
自身のアドレスから n バイトを引いた新しい Pointer オブジェクトを返します。
...から n バイトを引いた新しい Pointer オブジェクトを返します。
この返り値には、free 関数がセットされず、size は 0 とされます。
@param n アドレスの差分を整数で指定します。
例:
require 'fiddle'
s = 'abc'
cptr = Fiddle::Pointer[s...