550件ヒット
[1-100件を表示]
(0.040秒)
クラス
-
Fiddle
:: CStruct (22) -
Fiddle
:: Closure (33) -
Fiddle
:: Closure :: BlockCaller (11) -
Fiddle
:: Function (55) -
Fiddle
:: Handle (77) -
Fiddle
:: Pointer (231)
モジュール
-
Fiddle
:: Importer (121)
キーワード
- + (11)
- +@ (11)
- -@ (11)
- <=> (11)
- == (11)
- [] (44)
- abi (11)
- args (11)
- bind (11)
- call (22)
- close (11)
-
close
_ enabled? (11) -
create
_ value (11) - ctype (11)
-
disable
_ close (11) - dlload (11)
-
enable
_ close (11) - eql? (11)
- extern (11)
- free (11)
-
import
_ symbol (11) - name (11)
- null? (11)
- ptr (22)
- ref (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 # -(n) -> Fiddle :: Pointer (18103.0) -
自身のアドレスから n バイトを引いた新しい Pointer オブジェクトを返します。
...この返り値には、free 関数がセットされず、size は 0 とされます。
@param n アドレスの差分を整数で指定します。
例:
require 'fiddle'
s = 'abc'
cptr = Fiddle::Pointer[s]
cptr += 1
p cptr[0,1] #=> "b"
cptr -= 1
p cptr[0,1] #=> "a"... -
Fiddle
:: Pointer # -@ -> Fiddle :: Pointer (6103.0) -
自身を指す Pointer オブジェクトを返します。 C 言語におけるポインタへのアドレス演算子の適用 &p と同じです。
...用 &p と同じです。
この返り値には、free 関数がセットされず、size は 0 とされます。
例:
require 'fiddle'
s = 'abc'
cptr = Fiddle::Pointer[s]
cref = cptr.ref
p cref.to_s(4).unpack('l*')[0] #=> 136121648
p cptr.to_i #=> 136121648
p cref.... -
Fiddle
:: Pointer # ref -> Fiddle :: Pointer (3103.0) -
自身を指す Pointer オブジェクトを返します。 C 言語におけるポインタへのアドレス演算子の適用 &p と同じです。
...用 &p と同じです。
この返り値には、free 関数がセットされず、size は 0 とされます。
例:
require 'fiddle'
s = 'abc'
cptr = Fiddle::Pointer[s]
cref = cptr.ref
p cref.to_s(4).unpack('l*')[0] #=> 136121648
p cptr.to_i #=> 136121648
p cref.... -
Fiddle
:: Importer # bind(signature , *opts) { . . . } -> Fiddle :: Function (120.0) -
Ruby のブロックを C の関数で wrap し、その関数をモジュールに インポートします。
...インポートします。
これでインポートされた関数はモジュール関数として定義されます。
また、Fiddle::Importer#[] で Fiddle::Function オブジェクトとして
取り出すことができます。
signature で関数の名前とシネグチャを指定し......す。
@return インポートした関数を表す Fiddle::Function オブジェクトを返します。
@param signature 関数の名前とシネグチャ
@param opts オプション
例
require 'fiddle/import'
module M
extend Fiddle::Importer
dlload "libc.so.6"
typealias "si......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.qsort(Fiddle::Pointer[data], 6, Fiddle::SIZEOF_INT, M["compare"])
p data.unpack("i!*") # => [-13, -1, 0, 32, 49, 1... -
Fiddle
:: Pointer # <=>(other) -> Integer (109.0) -
ポインタの指すアドレスの大小を比較します。
...ポインタの指すアドレスの大小を比較します。
other より小さい場合は -1, 等しい場合は 0、other より大きい場合は
1を返します。
@param other 比較対象の Pointer オブジェクト... -
Fiddle
:: Importer # extern(signature , *opts) -> Fiddle :: Function (108.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 s......trcmp(char*, char*)"
end
M.strcmp("abc", "abc") # => 0
M.strcmp("abc", "abd") # => -1... -
Fiddle
:: Closure # args -> [Integer] (103.0) -
引数の型を表す配列を返します。
引数の型を表す配列を返します。 -
Fiddle
:: Closure # ctype -> Integer (103.0) -
返り値の型を返します。
返り値の型を返します。 -
Fiddle
:: Closure # to _ i -> Integer (103.0) -
C の関数ポインタのアドレスを返します。
C の関数ポインタのアドレスを返します。 -
Fiddle
:: Closure :: BlockCaller # call(*args) -> object (103.0) -
wrap しているブロックを呼び出します。
wrap しているブロックを呼び出します。
そのブロックの返り値がこのメソッドの返り値となります。
@param args 引数