種類
ライブラリ
- English (44)
- ビルトイン (575)
-
cgi
/ core (11) -
cgi
/ html (44) - csv (121)
-
digest
/ md5 (11) - erb (11)
-
fiddle
/ import (22) - fileutils (11)
- json (66)
-
net
/ ftp (132) -
net
/ http (253) -
net
/ imap (198) -
net
/ smtp (22) - objspace (44)
- open3 (33)
- openssl (1078)
- optparse (11)
- ostruct (39)
- pstore (11)
- psych (6)
-
rdoc
/ code _ object (11) - resolv (11)
-
rexml
/ document (77) -
rexml
/ parsers / pullparser (11) -
rexml
/ parsers / sax2parser (55) -
rexml
/ sax2listener (22) -
rexml
/ streamlistener (11) -
ripper
/ filter (22) -
ripper
/ lexer (11) -
rubygems
/ package / tar _ input (22) -
rubygems
/ package / tar _ output (55) -
rubygems
/ package / tar _ writer (22) -
rubygems
/ security (99) -
rubygems
/ source _ info _ cache (88) -
rubygems
/ validator (33) - socket (748)
- uri (44)
-
webrick
/ accesslog (11) -
webrick
/ httprequest (11) -
webrick
/ httputils (143) -
win32
/ registry (396) - zlib (66)
クラス
- BasicObject (33)
- BasicSocket (33)
- CGI (11)
- CSV (99)
-
CSV
:: Row (11) - Data (36)
- ERB (11)
-
Gem
:: Package :: TarInput (22) -
Gem
:: Package :: TarOutput (55) -
Gem
:: Package :: TarWriter :: BoundedStream (11) -
Gem
:: Package :: TarWriter :: RestrictedStream (11) -
Gem
:: Security :: Policy (33) -
Gem
:: Security :: Signer (11) -
Gem
:: SourceInfoCache (88) -
Gem
:: Validator (33) - IO (44)
-
JSON
:: Parser (33) -
JSON
:: State (22) - MatchData (268)
-
Net
:: FTP (132) -
Net
:: HTTP (176) -
Net
:: HTTPGenericRequest (22) -
Net
:: IMAP (44) -
Net
:: IMAP :: ContinuationRequest (22) -
Net
:: IMAP :: FetchData (22) -
Net
:: IMAP :: ResponseCode (11) -
Net
:: IMAP :: StatusData (22) -
Net
:: IMAP :: TaggedResponse (22) -
Net
:: IMAP :: UntaggedResponse (22) -
Net
:: SMTP (22) - Object (11)
-
OpenSSL
:: ASN1 :: ASN1Data (88) -
OpenSSL
:: ASN1 :: Constructive (11) -
OpenSSL
:: ASN1 :: Primitive (11) -
OpenSSL
:: ASN1 :: Sequence (22) -
OpenSSL
:: ASN1 :: Set (22) -
OpenSSL
:: Cipher (11) -
OpenSSL
:: Digest (44) -
OpenSSL
:: Digest :: DSS (33) -
OpenSSL
:: Digest :: DSS1 (33) -
OpenSSL
:: Digest :: MD2 (33) -
OpenSSL
:: Digest :: MD4 (33) -
OpenSSL
:: Digest :: MD5 (33) -
OpenSSL
:: Digest :: MDC2 (33) -
OpenSSL
:: Digest :: RIPEMD160 (33) -
OpenSSL
:: Digest :: SHA (33) -
OpenSSL
:: Digest :: SHA1 (33) -
OpenSSL
:: Digest :: SHA224 (33) -
OpenSSL
:: Digest :: SHA256 (33) -
OpenSSL
:: Digest :: SHA384 (33) -
OpenSSL
:: Digest :: SHA512 (33) -
OpenSSL
:: Engine (22) -
OpenSSL
:: HMAC (44) -
OpenSSL
:: PKCS7 (88) -
OpenSSL
:: PKey :: DSA (22) -
OpenSSL
:: PKey :: EC (22) -
OpenSSL
:: PKey :: PKey (22) -
OpenSSL
:: X509 :: Attribute (44) -
OpenSSL
:: X509 :: Extension (22) - OpenStruct (39)
- OptionParser (11)
- PStore (11)
- Proc (6)
-
RDoc
:: CodeObject (11) -
REXML
:: CData (44) -
REXML
:: Element (11) -
REXML
:: Entity (11) -
REXML
:: Parsers :: PullEvent (11) -
REXML
:: Parsers :: SAX2Parser (55) - Regexp (22)
-
Resolv
:: DNS :: Resource :: TXT (11) - Ripper (11)
-
Ripper
:: Filter (22) -
RubyVM
:: InstructionSequence (18) - Socket (220)
-
Socket
:: AncillaryData (187) -
Socket
:: Option (77) - String (11)
- Symbol (8)
-
WEBrick
:: HTTPRequest (11) -
WEBrick
:: HTTPUtils :: FormData (132) -
Win32
:: Registry (121) -
Zlib
:: ZStream (11)
モジュール
-
CGI
:: HtmlExtension (44) -
Fiddle
:: Importer (22) - FileUtils (11)
-
GC
:: Profiler (11) -
Gem
:: Security (55) - Kernel (55)
- Marshal (22)
-
Net
:: HTTPHeader (55) - ObjectSpace (44)
- Open3 (33)
-
OpenSSL
:: ASN1 (66) - Process (44)
- Psych (6)
-
REXML
:: SAX2Listener (22) -
REXML
:: StreamListener (11) -
Socket
:: Constants (220) - URI (44)
-
WEBrick
:: AccessLog (11) -
Win32
:: Registry :: API (176) -
Win32
:: Registry :: Constants (99) - Zlib (33)
キーワード
-
$ INPUT _ RECORD _ SEPARATOR (11) -
$ LAST _ MATCH _ INFO (11) -
$ LAST _ PAREN _ MATCH (11) -
$ RS (11) -
$ ~ (11) - << (39)
- == (13)
-
AF
_ DATAKIT (22) -
AF
_ DLI (22) - ASCII (11)
- ASN1 (11)
- ASN1Data (11)
- AlmostNoSecurity (11)
- AncillaryData (11)
- BINARY (11)
- CData (11)
- CSV (11)
- Cipher (11)
- CircularDatastructure (11)
- CloseKey (11)
- CreateKey (11)
-
DATA
_ PTR (11) - DSA (11)
- DataError (11)
- DataFormatError (11)
-
Data
_ Get _ Struct (11) -
Data
_ Make _ Struct (11) -
Data
_ Wrap _ Struct (11) - DeleteKey (11)
- DeleteValue (11)
- Digest (11)
-
EAI
_ NODATA (22) -
EMPTY
_ MARSHAL _ DATA (11) - ENODATA (11)
- EnumKey (11)
- EnumValue (11)
- ErrorData (11)
- Extension (11)
- FetchData (11)
- FlushKey (11)
- FormData (11)
-
HKEY
_ CLASSES _ ROOT (22) -
HKEY
_ CURRENT _ CONFIG (22) -
HKEY
_ CURRENT _ USER (22) -
HKEY
_ DYN _ DATA (22) -
HKEY
_ LOCAL _ MACHINE (22) -
HKEY
_ PERFORMANCE _ DATA (22) -
HKEY
_ PERFORMANCE _ NLSTEXT (22) -
HKEY
_ PERFORMANCE _ TEXT (22) -
HKEY
_ USERS (22) - HighSecurity (11)
-
IFF
_ OVS _ DATAPATH (22) -
IP
_ HDRINCL (22) - LowSecurity (11)
-
MAX
_ MULTIPART _ LENGTH (11) - MD5 (11)
-
MSG
_ CTRUNC (22) -
MSG
_ EOF (22) -
MSG
_ EOR (22) -
MSG
_ HAVEMORE (22) -
MSG
_ OOB (22) -
MSG
_ RCVMORE (22) -
MSG
_ TRUNC (22) - MatchData (11)
- MediumSecurity (11)
-
NEWS for Ruby 2
. 0 . 0 (11) -
NEWS for Ruby 2
. 1 . 0 (11) -
NEWS for Ruby 2
. 3 . 0 (9) -
NEWS for Ruby 2
. 4 . 0 (8) -
NEWS for Ruby 2
. 5 . 0 (7) -
NEWS for Ruby 3
. 0 . 0 (4) - NoSecurity (11)
- OpenKey (11)
-
PF
_ DATAKIT (22) -
PF
_ DLI (22) - PKey (11)
- QueryInfoKey (11)
- QueryValue (11)
- RDATA (11)
-
RLIMIT
_ DATA (11) - RSA (11)
-
RUBY
_ DATA _ FUNC (11) - ReFe (11)
- Ruby用語集 (11)
-
SEEK
_ DATA (11) -
SO
_ DONTTRUNC (22) -
SO
_ LINGER (22) -
SO
_ OOBINLINE (22) -
SO
_ WANTMORE (22) -
SO
_ WANTOOBFLAG (22) - Sequence (22)
- Set (22)
- SetValue (11)
- StatusData (11)
-
TCP
_ DEFER _ ACCEPT (22) - UNKNOWN (11)
- ZStream (11)
- [] (59)
-
add
_ data (11) -
add
_ gem _ contents (11) -
add
_ signatures (11) - alien (11)
-
append
_ data (11) - attr (22)
- begin (11)
- bind (11)
-
blk
_ free (11) -
blk
_ mark (11) -
blk
_ orphan (11) -
bm
_ mark (11) - body (11)
- body= (11)
- bool (11)
- byteoffset (4)
-
cache
_ data (22) -
call
_ end _ proc (11) - capture2 (11)
- capture2e (11)
- capture3 (11)
- captures (11)
- cdata (22)
- cdata? (11)
- cdatas (11)
- check (11)
- clone (11)
-
cmsg
_ is? (11) -
content
_ type (11) -
content
_ type= (11) -
count
_ objects _ size (11) -
count
_ tdata _ objects (11) - csv (11)
- data (110)
- data= (11)
-
data
_ type (11) - decode (11)
-
decode
_ all (11) -
decode
_ www _ form (11) -
decode
_ www _ form _ component (11) - deconstruct (2)
-
deconstruct
_ keys (2) - define (4)
- depth (11)
- depth= (11)
- digest (165)
-
digest
/ md5 (11) -
dsa
_ sign _ asn1 (11) -
dsa
_ verify _ asn1 (11) - dump (22)
- each (11)
-
each
_ data (11) -
each
_ pair (22) -
encode
_ www _ form (11) -
encode
_ www _ form _ component (11) - encrypt (11)
- end (11)
- environment (11)
- eql? (13)
- escape (11)
- family (11)
- fcntl (11)
- fdatasync (11)
- fetch (11)
- field? (11)
-
field
_ size _ limit (11) - filename (11)
- filename= (11)
-
form
_ data= (11) - get (22)
- getbinaryfile (22)
- getrlimit (11)
- gets (11)
- hash (13)
- hexdigest (154)
- inspect (13)
- instance (22)
-
instance
_ eval (22) - int (33)
-
ip
_ pktinfo (22) -
ipv6
_ pktinfo (22) -
ipv6
_ pktinfo _ addr (11) -
ipv6
_ pktinfo _ ifindex (11) - json (11)
-
last
_ match (11) -
latest
_ cache _ data (11) - length (11)
- level (11)
- linger (11)
- list (11)
- listen (55)
-
load
_ from _ binary _ extra _ data (9) -
load
_ private _ key (11) -
load
_ public _ key (11) - mailbox (11)
- match (30)
- members (4)
-
memsize
_ of (11) -
memsize
_ of _ all (11) -
method
_ missing (11) - mkdir (11)
-
multipart
_ form (44) - name (11)
- name= (11)
-
named
_ captures (11) - names (11)
- ndata (11)
-
net
/ http (11) - new (345)
- offset (22)
-
on
_ XXX (11) -
on
_ default (11) - open (11)
- packdw (11)
- packqw (11)
- parse (11)
- patch (22)
- post (22)
- post2 (22)
-
post
_ match (11) -
pre
_ match (11) -
proc
_ get _ safe _ level (11) -
proc
_ save _ safe _ level (11) -
proc
_ set _ safe _ level (11) -
processing
_ instruction (11) - put (33)
- put2 (22)
- putbinaryfile (22)
- query (11)
-
raw
_ data (44) -
rb
_ catch (11) -
rb
_ const _ list (11) -
rb
_ data _ object _ alloc (11) -
rb
_ ensure (11) -
rb
_ iterate (11) -
rb
_ mod _ const _ at (11) -
rb
_ mod _ const _ of (11) -
rb
_ protect (11) -
rb
_ rescue (11) -
rb
_ rescue2 (11) -
rb
_ set _ end _ proc (11) -
rb
_ thread _ check (11) -
rb
_ with _ disable _ interrupt (11) -
rdoc
/ generator / json _ index (11) - read (22)
-
read
_ all _ cache _ data (11) -
read
_ cache _ data (11) - readline (11)
- readlines (11)
- recvmsg (11)
-
recvmsg
_ nonblock (11) - regexp (11)
- request (22)
-
request
_ post (22) -
request
_ put (22) -
reset
_ cache _ data (11) -
reset
_ cache _ for (11) - retrbinary (22)
-
ruby 1
. 8 . 4 feature (11) -
ruby 1
. 8 . 5 feature (11) -
ruby 1
. 9 feature (11) -
rubygems
/ security (11) -
safe
_ load (6) - seek (11)
-
send
_ request (11) - sendmsg (11)
- seqno (11)
-
set
_ cache _ data (11) -
set
_ content _ type (11) -
set
_ form _ data (11) - setrlimit (22)
- shift (11)
- sign (33)
- size (11)
- source (11)
- storbinary (22)
- store (11)
- string (11)
- sysseek (11)
- syssign (11)
- sysverify (11)
- tag (11)
- tag= (11)
-
tag
_ class (11) -
tag
_ class= (11) - tagging (22)
-
to
_ a (11) -
to
_ ary (11) -
to
_ binary (9) -
to
_ der (11) -
to
_ h (21) -
to
_ s (46) -
token
_ match (11) -
trace
_ ev (11) - type (22)
-
uid
_ fetch (11) -
uid
_ store (11) -
undef
_ setter (11) - union (11)
-
unix
_ rights (22) - unpack (11)
- unpackdw (11)
- unpackqw (11)
- update (33)
-
val
_ marker (11) -
val
_ setter (11) - value (33)
- value= (22)
-
values
_ at (11) - verify (22)
-
verify
_ data (11) -
verify
_ data= (11) -
verify
_ gem (22) -
webrick
/ cgi (11) -
win32
/ registry (11) - with (2)
- write (33)
-
write
_ smime (11) - yaml (11)
- メソッド呼び出し(super・ブロック付き・yield) (11)
- 制御構造 (11)
検索結果
先頭5件
-
Data (44072.0)
-
「値オブジェクト(value object)」の定義に利用できるクラスです。
このクラスは Ruby 3.0 で削除されました。
拡張ライブラリを書く時に new が定義されているとまずい場合が
あるため、Object から new と allocate を undef したクラスです。
Ruby スクリプトレベルでは気にする必要は全くありません。...はありません。
Data.define でオブジェクトのクラスを定義できます。定義されたクラスは Data のサブクラスとなります。
Data のサブクラスでは、メンバに対するアクセスメソッドが定義されています。
Data と似たクラスに St......列挙が可能であるなど、
よりコンテナ風の API を提供するクラスです。
//emlist[例][ruby]{
# Dogクラスを定義
Dog = Data.define(:name, :age)
# Dogクラスのインスタンスを作成
fred = Dog.new("Fred", 5)
# メンバにアクセスできる
p fred.name # =>......"Fred"
# キーワード引数でも構築できる
p Dog.new(name: "Terry", age: 3)
# メンバの値を書き換えることはできない
fred.age = 6 # => NoMethodError
//}
なお、Ruby 2.7 以前に存在し Ruby 3.0 で削除された Data クラスとは異なります。... -
Data
. [](**kwargs) -> Data (30336.0) -
(このメソッドは Data のサブクラスにのみ定義されています) 値オブジェクトを生成して返します。
...(このメソッドは Data のサブクラスにのみ定義されています)
値オブジェクトを生成して返します。
@param args 値オブジェクトのメンバの値を指定します。
@param kwargs 値オブジェクトのメンバの値を指定します。
@return 値オ......aise ArgumentError 値オブジェクトのメンバの数より多くの引数を渡した場合に発生します。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
p1 = Point.new(1, 2)
p p1.x # => 1
p p1.y # => 2
p2 = Point.new(x: 3, y: 4)
p p2.x # => 3
p p2.y # => 4
//}
new......ケースではエラーの発生箇所は new ではなく initialize であることに注意してください。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
Point.new(1) # => in `initialize': missing keyword: :y (ArgumentError)
Point.new(1, 2, 3) # => in `new': w... -
Data
. [](*args) -> Data (30336.0) -
(このメソッドは Data のサブクラスにのみ定義されています) 値オブジェクトを生成して返します。
...(このメソッドは Data のサブクラスにのみ定義されています)
値オブジェクトを生成して返します。
@param args 値オブジェクトのメンバの値を指定します。
@param kwargs 値オブジェクトのメンバの値を指定します。
@return 値オ......aise ArgumentError 値オブジェクトのメンバの数より多くの引数を渡した場合に発生します。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
p1 = Point.new(1, 2)
p p1.x # => 1
p p1.y # => 2
p2 = Point.new(x: 3, y: 4)
p p2.x # => 3
p p2.y # => 4
//}
new......ケースではエラーの発生箇所は new ではなく initialize であることに注意してください。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
Point.new(1) # => in `initialize': missing keyword: :y (ArgumentError)
Point.new(1, 2, 3) # => in `new': w... -
Data
. new(**kwargs) -> Data (30336.0) -
(このメソッドは Data のサブクラスにのみ定義されています) 値オブジェクトを生成して返します。
...(このメソッドは Data のサブクラスにのみ定義されています)
値オブジェクトを生成して返します。
@param args 値オブジェクトのメンバの値を指定します。
@param kwargs 値オブジェクトのメンバの値を指定します。
@return 値オ......aise ArgumentError 値オブジェクトのメンバの数より多くの引数を渡した場合に発生します。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
p1 = Point.new(1, 2)
p p1.x # => 1
p p1.y # => 2
p2 = Point.new(x: 3, y: 4)
p p2.x # => 3
p p2.y # => 4
//}
new......ケースではエラーの発生箇所は new ではなく initialize であることに注意してください。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
Point.new(1) # => in `initialize': missing keyword: :y (ArgumentError)
Point.new(1, 2, 3) # => in `new': w... -
Data
. new(*args) -> Data (30336.0) -
(このメソッドは Data のサブクラスにのみ定義されています) 値オブジェクトを生成して返します。
...(このメソッドは Data のサブクラスにのみ定義されています)
値オブジェクトを生成して返します。
@param args 値オブジェクトのメンバの値を指定します。
@param kwargs 値オブジェクトのメンバの値を指定します。
@return 値オ......aise ArgumentError 値オブジェクトのメンバの数より多くの引数を渡した場合に発生します。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
p1 = Point.new(1, 2)
p p1.x # => 1
p p1.y # => 2
p2 = Point.new(x: 3, y: 4)
p p2.x # => 3
p p2.y # => 4
//}
new......ケースではエラーの発生箇所は new ではなく initialize であることに注意してください。
//emlist[例][ruby]{
Point = Data.define(:x, :y)
Point.new(1) # => in `initialize': missing keyword: :y (ArgumentError)
Point.new(1, 2, 3) # => in `new': w... -
Data
# with(**kwargs) -> Data (30310.0) -
self をコピーしたオブジェクトを返します。
...場合に発生します。
//emlist[例][ruby]{
Dog = Data.define(:name, :age)
dog1 = Dog.new("Fred", 5) # => #<data Dog name="Fred", age=5>
dog2 = dog1.with(age: 6) # => #<data Dog name="Fred", age=6>
p dog1 # => #<data Dog name="Fred", age=5>
dog3 = dog1.with(type: "Terrie......dog1.name.upcase!
p dog1 # => #<data Dog name="FRED", age=5>
p dog2 # => #<data Dog name="FRED", age=6>
//}
[注意] 本メソッドの記述は Data のサブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する... -
Data
. define(*args) -> Class (30188.0) -
Data クラスに新しいサブクラスを作って、それを返します。
...
Data クラスに新しいサブクラスを作って、それを返します。
サブクラスでは値オブジェクトのメンバに対するアクセスメソッドが定義されています。
//emlist[例][ruby]{
Dog = Data.define(:name, :age)
fred = Dog.new("Fred", 5)
p fred.name # =>......ruby]{
Dog = Data.define(:name, :age)
fred = Dog.new("Fred", 5)
fred.age = 6 # => NoMethodError
//}
メンバを持たないサブクラスも定義可能です。
以下のように、パターンマッチに利用できます。
//emlist[例][ruby]{
class HTTPFetcher
Response = Data.define(:bo......dy)
NotFound = Data.define
def get(url)
# ダミーの実装
if url == "http://example.com/"
Response.new(body: "Current time is #{Time.now}")
else
NotFound.new
end
end
end
def fetch(url)
fetcher = HTTPFetcher.new
case fetcher.get(url)
in HTTPFetcher::Respon... -
Data
. define(*args) {|subclass| block } -> Class (30188.0) -
Data クラスに新しいサブクラスを作って、それを返します。
...
Data クラスに新しいサブクラスを作って、それを返します。
サブクラスでは値オブジェクトのメンバに対するアクセスメソッドが定義されています。
//emlist[例][ruby]{
Dog = Data.define(:name, :age)
fred = Dog.new("Fred", 5)
p fred.name # =>......ruby]{
Dog = Data.define(:name, :age)
fred = Dog.new("Fred", 5)
fred.age = 6 # => NoMethodError
//}
メンバを持たないサブクラスも定義可能です。
以下のように、パターンマッチに利用できます。
//emlist[例][ruby]{
class HTTPFetcher
Response = Data.define(:bo......dy)
NotFound = Data.define
def get(url)
# ダミーの実装
if url == "http://example.com/"
Response.new(body: "Current time is #{Time.now}")
else
NotFound.new
end
end
end
def fetch(url)
fetcher = HTTPFetcher.new
case fetcher.get(url)
in HTTPFetcher::Respon... -
Data
# hash -> Integer (30080.0) -
自身のハッシュ値を整数で返します。 Data#eql? で比較して等しいオブジェクトは同じハッシュ値を返します。
...自身のハッシュ値を整数で返します。
Data#eql? で比較して等しいオブジェクトは同じハッシュ値を返します。
//emlist[例][ruby]{
Dog = Data.define(:name, :age)
dog1 = Dog.new("Fred", 5)
p dog1.hash # => -3931425561194935428
dog2 = Dog.new("Fred", 5)
p dog2.ha......w("Fred", 6)
p dog3.hash # => -4469132459285820530
//}
[注意] 本メソッドの記述は Data のサブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。
@see Object#hash... -
Data
# ==(other) -> bool (30060.0) -
self と other のクラスが同じであり、各メンバが == メソッドで比較して等しい場合に true を返します。そうでない場合に false を返します。
...Dog = Data.define(:name, :age)
dog1 = Dog.new("Fred", 5)
dog2 = Dog.new("Fred", 5.0)
p 5 == 5.0 # => true
p 5.eql?(5.0) # => false
p dog1 == dog2 # => true
p dog1.eql?(dog2) # => false
p dog1.equal?(dog2) # => false
//}
[注意] 本メソッドの記述は Data の......サブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。
@see Object#==, Data#eql?... -
Data
# deconstruct -> array (30060.0) -
self のメンバの値を配列で返します。
...。
//emlist[例][ruby]{
Measure = Data.define(:amount, :unit)
distance = Measure.new(10, 'km')
distance.deconstruct # => [10, "km"]
//}
このメソッドは以下のようにパターンマッチで利用されます。
//emlist[例][ruby]{
Measure = Data.define(:amount, :unit)
distance = Meas......ce
in Measure(n, 'km')
puts "It is #{n} kilometers away"
# ...
end
//}
[注意] 本メソッドの記述は Data のサブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# deconstruct _ keys(array _ of _ names _ or _ nil) -> hash (30060.0) -
self のメンバの名前と値の組を Hash で返します。
...self のメンバの名前と値の組を Hash で返します。
//emlist[例][ruby]{
Measure = Data.define(:amount, :unit)
distance = Measure.new(10, 'km')
distance.deconstruct_keys(nil) # => {:amount=>10, :unit=>"km"}
distance.deconstruct_keys([:amount]) # => {:amount=>10}
//}
このメ......ソッドは以下のようにパターンマッチで利用されます。
//emlist[例][ruby]{
Measure = Data.define(:amount, :unit)
distance = Measure.new(10, 'km')
case distance
in amount:, unit: 'km' # 裏側で #deconstruct_keys を呼ぶ
puts "It is #{amount} kilometers away"
else
puts......定します。nil の場合は全てのメンバを意味します。
[注意] 本メソッドの記述は Data のサブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# eql?(other) -> bool (30060.0) -
self と other のクラスが同じであり、各メンバが eql? メソッドで比較して等しい場合に true を返します。そうでない場合に false を返します。
...//emlist[例][ruby]{
Dog = Data.define(:name, :age)
dog1 = Dog.new("Fred", 5)
dog2 = Dog.new("Fred", 5)
p dog1 == dog2 # => true
p dog1.eql?(dog2) # => true
p dog1.equal?(dog2) # => false
//}
[注意] 本メソッドの記述は Data のサブクラスのイ......ンスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。
@see Object#eql?, Data#==... -
Data
# inspect -> String (30060.0) -
self の内容を人間に読みやすい文字列にして返します。
...list[例][ruby]{
Customer = Data.define(:name, :address, :zip)
joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
joe.inspect # => "#<data Customer name=\"Joe Smith\", address=\"123 Maple, Anytown NC\", zip=12345>"
//}
[注意] 本メソッドの記述は Data のサブクラスのイ......ンスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# to _ h -> Hash (30060.0) -
self のメンバ名(Symbol)と値の組を Hash にして返します。
...self のメンバ名(Symbol)と値の組を Hash にして返します。
//emlist[例][ruby]{
Customer = Data.define(:name, :address, :zip)
Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345).to_h
# => {:name=>"Joe Smith", :address=>"123 Maple, Anytown NC", :zip=>12345}
//}
ブロックを......omer = Data.define(:name, :address, :zip)
Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345).to_h {|member, value|
[member, value*2]
} # => {:name=>"Joe SmithJoe Smith", :address=>"123 Maple, Anytown NC123 Maple, Anytown NC", :zip=>24690}
//}
[注意] 本メソッドの記述は Data の......サブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# to _ h {|member , value| block } -> Hash (30060.0) -
self のメンバ名(Symbol)と値の組を Hash にして返します。
...self のメンバ名(Symbol)と値の組を Hash にして返します。
//emlist[例][ruby]{
Customer = Data.define(:name, :address, :zip)
Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345).to_h
# => {:name=>"Joe Smith", :address=>"123 Maple, Anytown NC", :zip=>12345}
//}
ブロックを......omer = Data.define(:name, :address, :zip)
Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345).to_h {|member, value|
[member, value*2]
} # => {:name=>"Joe SmithJoe Smith", :address=>"123 Maple, Anytown NC123 Maple, Anytown NC", :zip=>24690}
//}
[注意] 本メソッドの記述は Data の......サブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# to _ s -> String (30060.0) -
self の内容を人間に読みやすい文字列にして返します。
...list[例][ruby]{
Customer = Data.define(:name, :address, :zip)
joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
joe.inspect # => "#<data Customer name=\"Joe Smith\", address=\"123 Maple, Anytown NC\", zip=12345>"
//}
[注意] 本メソッドの記述は Data のサブクラスのイ......ンスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成する点に
注意してください。... -
Data
# members -> [Symbol] (30048.0) -
値オブジェクトのメンバの名前(Symbol)の配列を返します。
...す。
//emlist[例][ruby]{
Foo = Data.define(:foo, :bar)
p Foo.new(1, 2).members # => [:foo, :bar]
//}
[注意] 本メソッドの記述は Data のサブクラスのインスタンスに対して呼び
出す事を想定しています。Data.define は Data のサブクラスを作成す... -
Data
. members -> [Symbol] (30012.0) -
値オブジェクトのメンバの名前(Symbol)の配列を返します。
...値オブジェクトのメンバの名前(Symbol)の配列を返します。
//emlist[例][ruby]{
Foo = Data.define(:foo, :bar)
p Foo.members # => [:foo, :bar]
//}... -
Object
:: DATA -> File (24406.0) -
スクリプトの __END__ プログラムの終り以降をアクセスする File オブジェクト。
...んでおくことができます。
DATA 定数はそのデータ部分にアクセスするための File オブジェクトを保持しています。
__END__ を含まないプログラムにおいては DATA は定義されません。
=== 注意
* DATA.rewind で移動する読みとり......ファイル ($0) を指します。
=== 例1
print DATA.gets # => 故人西辞黄鶴楼
print DATA.gets # => 烟花三月下揚州
print DATA.gets # => 孤帆遠影碧空尽
print DATA.gets # => 唯見長江天際流
DATA.gets # => nil
__END__
故人西辞黄......江天際流
=== 例2
sum = 0
DATA.each_line do |line|
sum += line.to_i
end
DATA.rewind
p DATA.gets # => "sum = 0¥n"
__END__
17
19
23
29
31
=== 例3
DATA.gets # => uninitialized constant DATA (NameError)
=== 例4
ファイル... -
WEBrick
:: HTTPUtils :: FormData # append _ data(data) -> self (18404.0) -
WEBrick::HTTPUtils の内部で使われます。ユーザがこのメソッドを直接呼ぶことはありません。
WEBrick::HTTPUtils の内部で使われます。ユーザがこのメソッドを直接呼ぶことはありません。 -
Socket
:: AncillaryData # data -> String (18234.0) -
自身が保持している cmsg data (データ) を返します。
...自身が保持している cmsg data (データ) を返します。
require 'socket'
p Socket::AncillaryData.new(:INET6, :IPV6, :PKTINFO, "").type
#=> ""
@see Socket::AncillaryData.new... -
WEBrick
:: HTTPUtils :: FormData # each _ data {|s| . . . } (18214.0) -
自身が表す各フォームデータを引数として、与えられたブロックを実行します。
...ムデータを引数として、与えられたブロックを実行します。
例:
require "webrick/cgi"
class MyCGI < WEBrick::CGI
def do_GET(req, res)
req.query['q'].each_data{|s|
p s
}
#=> "val1"
"val2"
"val3"
end
end
MyCGI.new.start()... -
VALUE rb
_ data _ object _ alloc(VALUE klass , void *datap , RUBY _ DATA _ FUNC dmark , RUBY _ DATA _ FUNC dfree) (12800.0) -
datap をラップするオブジェクトを生成し、返します。 そのクラスは klass となり、datap をマークするときは dmark、解放するときは dfree を使うようになります。
...
datap をラップするオブジェクトを生成し、返します。
そのクラスは klass となり、datap をマークするときは
dmark、解放するときは dfree を使うようになります。... -
VALUE Data
_ Make _ Struct(VALUE klass , type , RUBY _ DATA _ FUNC mark , RUBY _ DATA _ FUNC free , type *svar) (12636.0) -
type 型の構造体をヒープに割り当ててそれへのポインタを svar に代入し、クラス klass のインスタンスである Ruby のオブジェクトを生成し、それを返します。mark free はそれぞれマーク用・解放用の関数へのポインタです。 どちらも、必要ないときはかわりに 0 を渡します。
...へのポインタです。
どちらも、必要ないときはかわりに 0 を渡します。
また RUBY_DATA_FUNC の定義は以下のようです。
typedef void (*RUBY_DATA_FUNC)(void *st)
第一引数 st には svar の値が渡されます。
使用例
struct mytype {......int i;
char *s;
};
VALUE
my_s_new(klass)
VALUE klass;
{
struct mytype *dummy;
return Data_Make_Struct(MyClass, struct mytype,
mark_my, free_my, dummy);
}...