Class: StringIO
- Inherits:
-
IO
show all
- Includes:
- IO::Readable, IO::Writable
- Defined in:
- opal/stdlib/stringio.rb
Instance Attribute Summary collapse
Attributes inherited from IO
#lineno
Class Method Summary
collapse
Instance Method Summary
collapse
Methods inherited from IO
binread, #each_line, read, write
Constructor Details
#initialize(string = "", mode = 'rw') ⇒ StringIO
Returns a new instance of StringIO
15
16
17
18
19
20
21
22
23
24
|
# File 'opal/stdlib/stringio.rb', line 15
def initialize(string = "", mode = 'rw')
@string = string
@position = string.length
if mode.include?('r') and not mode.include?('w')
@closed = :write
elsif mode.include?('w') and not mode.include?('r')
@closed = :read
end
end
|
Instance Attribute Details
Returns the value of attribute string
13
14
15
|
# File 'opal/stdlib/stringio.rb', line 13
def string
@string
end
|
Class Method Details
.open(string = "", mode = nil, &block) ⇒ Object
5
6
7
8
9
10
11
|
# File 'opal/stdlib/stringio.rb', line 5
def self.open(string = "", mode = nil, &block)
io = new(string, mode)
res = block.call(io)
io.close
res
end
|
Instance Method Details
#check_readable ⇒ Object
176
177
178
179
180
|
# File 'opal/stdlib/stringio.rb', line 176
def check_readable
if closed_read?
raise IOError, "not opened for reading"
end
end
|
#check_writable ⇒ Object
170
171
172
173
174
|
# File 'opal/stdlib/stringio.rb', line 170
def check_writable
if closed_write?
raise IOError, "not opened for writing"
end
end
|
138
139
140
|
# File 'opal/stdlib/stringio.rb', line 138
def close
@closed = :both
end
|
#close_read ⇒ Object
142
143
144
145
146
147
148
|
# File 'opal/stdlib/stringio.rb', line 142
def close_read
if @closed == :write
@closed = :both
else
@closed = :read
end
end
|
#close_write ⇒ Object
150
151
152
153
154
155
156
|
# File 'opal/stdlib/stringio.rb', line 150
def close_write
if @closed == :read
@closed = :both
else
@closed = :write
end
end
|
158
159
160
|
# File 'opal/stdlib/stringio.rb', line 158
def closed?
@closed == :both
end
|
#closed_read? ⇒ Boolean
162
163
164
|
# File 'opal/stdlib/stringio.rb', line 162
def closed_read?
@closed == :read || @closed == :both
end
|
#closed_write? ⇒ Boolean
166
167
168
|
# File 'opal/stdlib/stringio.rb', line 166
def closed_write?
@closed == :write || @closed == :both
end
|
#each_byte(&block) ⇒ Object
71
72
73
74
75
76
77
78
79
80
81
82
83
|
# File 'opal/stdlib/stringio.rb', line 71
def each_byte(&block)
return enum_for :each_byte unless block
check_readable
i = @position
until eof?
block.call(@string[i].ord)
i += 1
end
self
end
|
#each_char(&block) ⇒ Object
85
86
87
88
89
90
91
92
93
94
95
96
97
|
# File 'opal/stdlib/stringio.rb', line 85
def each_char(&block)
return enum_for :each_char unless block
check_readable
i = @position
until eof?
block.call(@string[i])
i += 1
end
self
end
|
#eof? ⇒ Boolean
Also known as:
eof
26
27
28
29
30
|
# File 'opal/stdlib/stringio.rb', line 26
def eof?
check_readable
@position == @string.length
end
|
#read(length = nil, outbuf = nil) ⇒ Object
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
|
# File 'opal/stdlib/stringio.rb', line 116
def read(length = nil, outbuf = nil)
check_readable
return if eof?
string = if length
str = @string[@position, length]
@position += length
str
else
str = @string[@position .. -1]
@position = @string.length
str
end
if outbuf
outbuf.write(string)
else
string
end
end
|
67
68
69
|
# File 'opal/stdlib/stringio.rb', line 67
def rewind
seek 0
end
|
#seek(pos, whence = IO::SEEK_SET) ⇒ Object
Also known as:
pos=
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
# File 'opal/stdlib/stringio.rb', line 34
def seek(pos, whence = IO::SEEK_SET)
case whence
when IO::SEEK_SET
raise Errno::EINVAL unless pos >= 0
@position = pos
when IO::SEEK_CUR
if @position + pos > @string.length
@position = @string.length
else
@position += pos
end
when IO::SEEK_END
if pos > @string.length
@position = 0
else
@position -= pos
end
end
0
end
|
#tell ⇒ Object
Also known as:
pos
59
60
61
|
# File 'opal/stdlib/stringio.rb', line 59
def tell
@position
end
|
#write(string) ⇒ Object
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
# File 'opal/stdlib/stringio.rb', line 99
def write(string)
check_writable
string = String(string)
if @string.length == @position
@string += string
@position += string.length
else
before = @string[0 .. @position - 1]
after = @string[@position + string.length .. -1]
@string = before + string + after
@position += string.length
end
end
|