ライブラリ
- fiddle (15)
-
fiddle
/ import (2) - resolv (4)
- win32ole (3)
クラス
-
Fiddle
:: CStruct (1) -
Fiddle
:: Function (3) -
Fiddle
:: Pointer (2) -
Resolv
:: DNS (2) -
WIN32OLE
_ METHOD (1) -
WIN32OLE
_ PARAM (1)
モジュール
- Fiddle (10)
-
Fiddle
:: Importer (1) -
WIN32OLE
:: VARIANT (1)
キーワード
-
ALIGN
_ INTPTR _ T (1) -
ALIGN
_ PTRDIFF _ T (1) -
ALIGN
_ UINTPTR _ T (1) -
DATA
_ PTR (1) - NULL (1)
- PTR (2)
-
RSTRING
_ END (1) -
RSTRING
_ PTR (1) -
SIZEOF
_ INTPTR _ T (1) -
SIZEOF
_ PTRDIFF _ T (1) -
SIZEOF
_ UINTPTR _ T (1) - StringValuePtr (1)
-
TYPE
_ INTPTR _ T (1) -
TYPE
_ PTRDIFF _ T (1) -
TYPE
_ UINTPTR _ T (1) -
VT
_ PTR (1) - call (1)
- getresource (1)
- getresources (1)
-
is
_ pointer _ to _ heap (1) -
lex
_ get _ str (1) - new (1)
-
ole
_ type _ detail (1) -
rb
_ ary _ entry (1) -
rb
_ gc _ mark _ children (1) -
rb
_ str _ cat (1) -
rb
_ str _ cat2 (1) -
rb
_ str _ new (1) -
rb
_ str _ new2 (1) -
return
_ type _ detail (1) -
ruby 1
. 6 feature (1) -
ruby
_ xrealloc (1) - struct (1)
-
to
_ ptr (2)
検索結果
先頭5件
-
Fiddle
:: Function # ptr -> Integer | Fiddle :: Function (72604.0) -
関数ポインタを返します。
関数ポインタを返します。
Fiddle::Function.new の第1引数として指定したものを返します。 -
char* RSTRING
_ PTR(RString str) (55501.0) -
引数 str の表す文字列のポインタの先頭を返します。
引数 str の表す文字列のポインタの先頭を返します。
@param str RString 構造体を指定します。
@see RSTRING_END -
char * StringValuePtr(VALUE val) (54901.0)
-
val が String でなければ to_str メソッドを使って String に変換し、 その実体のポインタを返します。
val が String でなければ to_str メソッドを使って String に変換し、
その実体のポインタを返します。
このマクロに渡した VALUE は ruby の GC から確実に保護されます。 -
Fiddle
:: Pointer # ptr -> Fiddle :: Pointer (54622.0) -
自身の指す値を Pointer にして返します。
自身の指す値を Pointer にして返します。
自身の指す値はポインタであると仮定します。
C 言語におけるポインタのポインタに対する間接参照 *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
... -
Fiddle
:: CStruct # to _ ptr -> Fiddle :: Pointer (45604.0) -
保持している構造体へのポインタを返します。
保持している構造体へのポインタを返します。 -
WIN32OLE
:: VARIANT :: VT _ PTR -> Integer (36622.0) -
ポインタ型を示します(26)。
ポインタ型を示します(26)。
VT_PTRは、VOID*に相当するため、OLEオートメーションでは利用できません。 -
Fiddle
:: ALIGN _ INTPTR _ T -> Integer (36601.0) -
C の構造体における intptr_t のアライメントの値。
C の構造体における intptr_t のアライメントの値。 -
Fiddle
:: ALIGN _ PTRDIFF _ T -> Integer (36601.0) -
C の構造体における ptrdiff_t のアライメントの値。
C の構造体における ptrdiff_t のアライメントの値。 -
Fiddle
:: ALIGN _ UINTPTR _ T -> Integer (36601.0) -
C の構造体における uintptr_t のアライメントの値。
C の構造体における uintptr_t のアライメントの値。 -
Fiddle
:: SIZEOF _ INTPTR _ T -> Integer (36601.0) -
Cでの sizeof(intptr_t) の値
Cでの sizeof(intptr_t) の値 -
Fiddle
:: SIZEOF _ PTRDIFF _ T -> Integer (36601.0) -
Cでの sizeof(ptrdiff_t) の値
Cでの sizeof(ptrdiff_t) の値 -
Fiddle
:: SIZEOF _ UINTPTR _ T -> Integer (36601.0) -
Cでの sizeof(uintptr_t) の値
Cでの sizeof(uintptr_t) の値 -
Fiddle
:: TYPE _ INTPTR _ T -> Integer (36601.0) -
C の intptr_t 型を表す定数。
C の intptr_t 型を表す定数。 -
Fiddle
:: TYPE _ PTRDIFF _ T -> Integer (36601.0) -
C の ptrdiff_t 型を表す定数。
C の ptrdiff_t 型を表す定数。 -
Fiddle
:: TYPE _ UINTPTR _ T -> Integer (36601.0) -
C の uintptr_t 型を表す定数。
C の uintptr_t 型を表す定数。 -
void * DATA
_ PTR(VALUE dta) (36601.0) -
実際は struct RData* 型である dta から、 それがラップしているポインタを取り出します。
実際は struct RData* 型である dta から、
それがラップしているポインタを取り出します。 -
Resolv
:: DNS :: Resource :: PTR (36085.0) -
DNS リソースの PTR レコード を表す抽象クラスです。
DNS リソースの PTR レコード
を表す抽象クラスです。
Resolv::DNS#getresource で PTR レコードを得たい場合は
Resolv::DNS::Resource::IN::PTR を使うべきです。 -
Resolv
:: DNS :: Resource :: IN :: PTR (36049.0) -
DNS リソースのクラス IN、タイプ PTR に対応する クラスです。
DNS リソースのクラス IN、タイプ PTR に対応する
クラスです。 -
VALUE rb
_ str _ cat2(VALUE str , const char *ptr) (19297.0) -
文字列 str に C の文字列 ptr を破壊的に 連結します。ptr はヌル終端を仮定しています。
文字列 str に C の文字列 ptr を破壊的に
連結します。ptr はヌル終端を仮定しています。 -
VALUE rb
_ str _ cat(VALUE str , const char *ptr , long len) (19249.0) -
文字列 str に、長さ len (NUL 含まず)の C の文字列 ptr を破壊的に連結します。
文字列 str に、長さ len (NUL 含まず)の C の文字列
ptr を破壊的に連結します。 -
VALUE rb
_ str _ new2(const char *ptr) (18997.0) -
rb_str_new(ptr, strlen(ptr))
rb_str_new(ptr, strlen(ptr)) -
VALUE rb
_ str _ new(const char *ptr , long len) (18949.0) -
ptr から len バイト分をコピーして Ruby の文字列を作成し返します。
ptr から len バイト分をコピーして
Ruby の文字列を作成し返します。
rb_str_new(0,0)
では空文字列を生成して返します。 -
char* RSTRING
_ END(RString str) (18919.0) -
引数 str の表す文字列のポインタの末尾を返します。
引数 str の表す文字列のポインタの末尾を返します。
@param str RString 構造体を指定します。
@see RSTRING_PTR -
Fiddle
:: Pointer . to _ ptr(val) -> Fiddle :: Pointer (18658.0) -
与えられた val と関連した Pointer オブジェクトを生成して返します。
与えられた val と関連した Pointer オブジェクトを生成して返します。
val が文字列の場合は文字列が格納されているメモリ領域を指す Pointer
オブジェクトを返します。
IO オブジェクトの場合は FILE ポインタを表す Pointer オブジェクトを返します。
val に to_ptr メソッドが定義されている場合は、val.to_ptr を呼び、
Pointer オブジェクトに変換したものを返します。
val が整数の場合はそれをアドレスとする Pointer オブジェクトを返します。
上以外の場合は、整数に変換(to_int)し
それをアドレスとする P... -
static VALUE lex
_ get _ str(VALUE s) (18397.0) -
文字列 s の lex_gets_ptr の後から一行取得し、返します。 lex_gets_ptr も進められます。
文字列 s の lex_gets_ptr の後から一行取得し、返します。
lex_gets_ptr も進められます。 -
Fiddle
:: Importer # struct(signature) -> Class (18319.0) -
C の構造体型に対応する Ruby のクラスを構築して返します。
C の構造体型に対応する Ruby のクラスを構築して返します。
構造体の各要素は C と似せた表記ができます。そしてそれを
配列で signature に渡してデータを定義します。例えば C における
struct timeval {
long tv_sec;
long tv_usec;
};
という構造体型に対応して
Timeval = struct(["long tv_sec", "long tv_usec"])
として構造体に対応するクラスを生成します。
このメソッドが返すクラスには以下のメソッドが定義されています
* クラスメソッド malloc
... -
Resolv
:: DNS # getresource(name , typeclass) -> Resolv :: DNS :: Resource (18319.0) -
nameに対応するDNSリソースレコードを取得します。 最初に見つかったリソースを返します。
nameに対応するDNSリソースレコードを取得します。
最初に見つかったリソースを返します。
typeclass は以下のいずれかです。
* Resolv::DNS::Resource::IN::ANY
* Resolv::DNS::Resource::IN::NS
* Resolv::DNS::Resource::IN::CNAME
* Resolv::DNS::Resource::IN::SOA
* Resolv::DNS::Resource::IN::HINFO
* Resolv::DNS::Resource::IN::MINFO
* Resolv::DNS... -
Resolv
:: DNS # getresources(name , typeclass) -> [Resolv :: DNS :: Resource] (18319.0) -
nameに対応するDNSリソースレコードを取得します。 見つかったリソース全てを配列にして返します。
nameに対応するDNSリソースレコードを取得します。
見つかったリソース全てを配列にして返します。
typeclass は以下のいずれかです。
* Resolv::DNS::Resource::IN::ANY
* Resolv::DNS::Resource::IN::NS
* Resolv::DNS::Resource::IN::CNAME
* Resolv::DNS::Resource::IN::SOA
* Resolv::DNS::Resource::IN::HINFO
* Resolv::DNS::Resource::IN::MINFO
* Resolv:... -
VALUE rb
_ ary _ entry(VALUE ary , long offset) (18319.0) -
ary のインデックス offset の要素を返します。
ary のインデックス offset の要素を返します。
インデックスが範囲を越えるときは Qnil を返します。
負のインデックスも使えます。
対応するRubyコード
ary[offset] または
ary.at(offset)
使用例
VALUE num;
num = rb_ary_entry(ary, offset);
printf("%d\n", FIX2INT(num));
キャストを使った要素の参照方法
VALUE num = RARRAY(ary)->ptr[offset]; -
Fiddle
:: Function . new(ptr , args , ret _ type , abi=Fiddle :: Function :: DEFAULT , name: nil) -> Fiddle :: Function (706.0) -
ptr (関数ポインタ)から Fiddle::Function オブジェクトを 生成します。
ptr (関数ポインタ)から Fiddle::Function オブジェクトを
生成します。
ptr には Fiddle::Handle から Fiddle::Handle#sym などで取りだした
関数ポインタ(を表す整数)、もしくは関数を指している
Fiddle::Pointer を渡します。
args、ret_type で関数の引数と返り値の型を指定します。これには以下の
定数が利用できます。「-TYPE_INT」 のように符号を反転させると unsigned を
意味します。
* Fiddle::TYPE_VOID
* Fiddle::TYPE_VOIDP
* Fidd... -
Fiddle
:: Function # call(*args) -> Integer|DL :: CPtr|nil (619.0) -
関数を呼び出します。
関数を呼び出します。
Fiddle::Function.new で指定した引数と返り値の型に基いて
Ruby のオブジェクトを適切に C のデータに変換して C の関数を呼び出し、
その返り値を Ruby のオブジェクトに変換して返します。
引数の変換は以下の通りです。
: void* (つまり任意のポインタ型)
nil ならば C の NULL に変換されます
Fiddle::Pointer は保持している C ポインタに変換されます。
文字列であればその先頭ポインタになります。
IO オブジェクトであれば FILE* が渡されます。
整数であればそれがアドレスとみ... -
Fiddle
:: NULL -> DL :: CPtr (601.0) -
C の NULL ポインタ
C の NULL ポインタ -
static inline int is
_ pointer _ to _ heap(void *ptr) (601.0) -
-
void * ruby
_ xrealloc(void *ptr , long size) (601.0) -
引数と返り値の意味は realloc() と同じ。 ただしメモリ割り当てに失敗したときは GC を行いそれでもだめなときは NoMemoryError を raise する。 つまりこの関数が返り値を返したときは常に割り当ては成功している。
引数と返り値の意味は realloc() と同じ。
ただしメモリ割り当てに失敗したときは
GC を行いそれでもだめなときは NoMemoryError を raise する。
つまりこの関数が返り値を返したときは常に割り当ては成功している。 -
void rb
_ gc _ mark _ children(VALUE ptr) (601.0) -
v から指されているオブジェクトを全てマークします。
v から指されているオブジェクトを全てマークします。 -
WIN32OLE
_ METHOD # return _ type _ detail -> [String] (319.0) -
返り値の型と属性を取得します。
返り値の型と属性を取得します。
@return 返り値の型と属性を文字列配列で返します。
tobj = WIN32OLE_TYPE.new('Microsoft Excel 14.0 Object Library', 'Application')
method = WIN32OLE_METHOD.new(tobj, 'Workbooks')
p method.return_type_detail # => ["PTR", "USERDEFINED", "Workbooks"]
属性が付加されていない場合は、WIN32OLE_METHOD#return_typeを要素と
... -
WIN32OLE
_ PARAM # ole _ type _ detail -> [String] (319.0) -
パラメータの属性を取得します。
パラメータの属性を取得します。
@return 型の属性を文字列配列で返します。
tobj = WIN32OLE_TYPE.new('Microsoft Excel 9.0 Object Library', 'IWorksheetFunction')
method = WIN32OLE_METHOD.new(tobj, 'SumIf')
param1 = method.params[0]
p param1.ole_type_detail # => ["PTR", "USERDEFINED", "Range"]
パラメータの取り得る属性値はCOMのIDL(インターフ... -
ruby 1
. 6 feature (217.0) -
ruby 1.6 feature ruby version 1.6 は安定版です。この版での変更はバグ修正がメイン になります。
ruby 1.6 feature
ruby version 1.6 は安定版です。この版での変更はバグ修正がメイン
になります。
((<stable-snapshot|URL:ftp://ftp.netlab.co.jp/pub/lang/ruby/stable-snapshot.tar.gz>)) は、日々更新される安定版の最新ソースです。
== 1.6.8 (2002-12-24) -> stable-snapshot
: 2003-01-22: errno
EAGAIN と EWOULDBLOCK が同じ値のシステムで、EWOULDBLOCK がなくなっ
ていま...