Linux server1.dn-server.com 4.18.0-553.89.1.lve.el8.x86_64 #1 SMP Wed Dec 10 13:58:50 UTC 2025 x86_64
LiteSpeed
Server IP : 195.201.204.189 & Your IP : 216.73.216.198
Domains :
Cant Read [ /etc/named.conf ]
User : beriska1
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
ruby32 /
share /
ri /
system /
Fiber /
Delete
Unzip
Name
Size
Permission
Date
Action
Pool
[ DIR ]
drwxr-xr-x
2026-05-05 23:08
Scheduler
[ DIR ]
drwxr-xr-x
2026-05-05 23:08
%5b%5d%3d-c.ri
533
B
-rw-r--r--
2026-04-07 17:42
%5b%5d-c.ri
508
B
-rw-r--r--
2026-04-07 17:42
alive%3f-i.ri
458
B
-rw-r--r--
2026-04-07 17:42
backtrace-i.ri
1.59
KB
-rw-r--r--
2026-04-07 17:42
backtrace_locations-i.ri
857
B
-rw-r--r--
2026-04-07 17:42
blocking%3f-c.ri
908
B
-rw-r--r--
2026-04-07 17:42
blocking%3f-i.ri
749
B
-rw-r--r--
2026-04-07 17:42
blocking-c.ri
513
B
-rw-r--r--
2026-04-07 17:42
cdesc-Fiber.ri
3.93
KB
-rw-r--r--
2026-04-07 17:42
current-c.ri
410
B
-rw-r--r--
2026-04-07 17:42
current_scheduler-c.ri
474
B
-rw-r--r--
2026-04-07 17:42
inspect-i.ri
235
B
-rw-r--r--
2026-04-07 17:42
new-c.ri
1.96
KB
-rw-r--r--
2026-04-07 17:42
raise-i.ri
1.33
KB
-rw-r--r--
2026-04-07 17:42
resume-i.ri
887
B
-rw-r--r--
2026-04-07 17:42
schedule-c.ri
1.62
KB
-rw-r--r--
2026-04-07 17:42
scheduler-c.ri
626
B
-rw-r--r--
2026-04-07 17:42
set_scheduler-c.ri
972
B
-rw-r--r--
2026-04-07 17:42
storage%3d-i.ri
1.01
KB
-rw-r--r--
2026-04-07 17:42
storage-i.ri
400
B
-rw-r--r--
2026-04-07 17:42
to_s-i.ri
232
B
-rw-r--r--
2026-04-07 17:42
transfer-i.ri
3.7
KB
-rw-r--r--
2026-04-07 17:42
yield-c.ri
616
B
-rw-r--r--
2026-04-07 17:42
Save
Rename
U:RDoc::NormalClass[iI" Fiber:ET@I"Object;To:RDoc::Markup::Document:@parts[o;;[$o:RDoc::Markup::Paragraph;[ I"EFibers are primitives for implementing light weight cooperative ;TI"Mconcurrency in Ruby. Basically they are a means of creating code blocks ;TI"Lthat can be paused and resumed, much like threads. The main difference ;TI"Nis that they are never preempted and that the scheduling must be done by ;TI"#the programmer and not the VM.;To:RDoc::Markup::BlankLine o; ;[ I"OAs opposed to other stackless light weight concurrency models, each fiber ;TI"Jcomes with a stack. This enables the fiber to be paused from deeply ;TI"Dnested function calls within the fiber block. See the ruby(1) ;TI"9manpage to configure the size of the fiber stack(s).;T@o; ;[ I"KWhen a fiber is created it will not run automatically. Rather it must ;TI"?be explicitly asked to run using the Fiber#resume method. ;TI"FThe code running inside the fiber can give up control by calling ;TI"EFiber.yield in which case it yields control back to caller (the ;TI"!caller of the Fiber#resume).;T@o; ;[I"JUpon yielding or termination the Fiber returns the value of the last ;TI"executed expression;T@o; ;[I"For instance:;T@o:RDoc::Markup::Verbatim;[ I"fiber = Fiber.new do ;TI" Fiber.yield 1 ;TI" 2 ;TI" end ;TI" ;TI"puts fiber.resume ;TI"puts fiber.resume ;TI"puts fiber.resume ;T:@format0o; ;[I"<em>produces</em>;T@o;;[I"1 ;TI"2 ;TI"#FiberError: dead fiber called ;T;0o; ;[ I"HThe Fiber#resume method accepts an arbitrary number of parameters, ;TI"Dif it is the first call to #resume then they will be passed as ;TI"Eblock arguments. Otherwise they will be the return value of the ;TI"call to Fiber.yield;T@o; ;[I" Example:;T@o;;[I""fiber = Fiber.new do |first| ;TI"& second = Fiber.yield first + 2 ;TI" end ;TI" ;TI"puts fiber.resume 10 ;TI"!puts fiber.resume 1_000_000 ;TI"Kputs fiber.resume "The fiber will be dead before I can cause trouble" ;T;0o; ;[I"<em>produces</em>;T@o;;[I"12 ;TI" 1000000 ;TI"#FiberError: dead fiber called ;T;0S:RDoc::Markup::Heading: leveli: textI"Non-blocking Fibers;T@o; ;[ I"LThe concept of <em>non-blocking fiber</em> was introduced in Ruby 3.0. ;TI"OA non-blocking fiber, when reaching a operation that would normally block ;TI"Mthe fiber (like <code>sleep</code>, or wait for another process or I/O) ;TI"Lwill yield control to other fibers and allow the <em>scheduler</em> to ;TI"Mhandle blocking and waking up (resuming) this fiber when it can proceed.;T@o; ;[ I"TFor a Fiber to behave as non-blocking, it need to be created in Fiber.new with ;TI"J<tt>blocking: false</tt> (which is the default), and Fiber.scheduler ;TI"Nshould be set with Fiber.set_scheduler. If Fiber.scheduler is not set in ;TI"Qthe current thread, blocking and non-blocking fibers' behavior is identical.;T@o; ;[I"QRuby doesn't provide a scheduler class: it is expected to be implemented by ;TI"1the user and correspond to Fiber::Scheduler.;T@o; ;[I"SThere is also Fiber.schedule method, which is expected to immediately perform ;TI"Rthe given block in a non-blocking manner. Its actual implementation is up to ;TI"the scheduler.;T: @fileI"cont.c;T:0@omit_headings_from_table_of_contents_below0;0;0[ [ [ [[I" class;T[[:public[ [:protected[ [:private[[I"[];TI"cont.c;T[I"[]=;T@}[I" blocking;T@}[I"blocking?;T@}[I"current;T@}[I"current_scheduler;T@}[I"new;T@}[I" schedule;T@}[I"scheduler;T@}[I"set_scheduler;T@}[I" yield;T@}[I" instance;T[[;[ [;[ [;[[I"alive?;T@}[I"backtrace;T@}[I"backtrace_locations;T@}[I"blocking?;T@}[I"inspect;T@}[I" raise;T@}[I"resume;T@}[I"storage;T@}[I" storage=;T@}[I" to_s;T@}[I" transfer;T@}[ [U:RDoc::Context::Section[i 0o;;[ ;0;0[I"cont.c;T@mcRDoc::TopLevel