Difference between revisions of "Parallel (API)"

From ComputerCraft Wiki
Jump to: navigation, search
(Added {{NeedsWork}} Tag)
m
 
(4 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{NeedsWork|This API needs explanation and examples. [[User:MKlegoman357|MKlegoman357]] 20:41, 6 April 2014 (GMT)}}
+
{{lowercase}}
 
+
 
Parallel is an API which allows you to multitask.
 
Parallel is an API which allows you to multitask.
  
{{API table|Parallel|image=Grid disk.png|2=
+
Functions are not actually executed simultaniously, but rather this API will automatically switch between them whenever they yield (eg whenever they call [[coroutine.yield]](), or functions that call that - eg [[os.pullEvent]]() - or functions that call that, etc - basically, anything that causes the function to "pause").
 +
 
 +
Each function executed in "parallel" gets its own copy of the event queue, and so "event consuming" functions (again, mostly anything that causes the script to pause - eg [[Os.sleep|sleep]](), [[rednet.receive]](), most of the [[Turtle (API)|turtle API]], etc) can safely be used in one without affecting the event queue accessed by the other.
 +
 
 +
{{API table|parallel|image=Grid disk.png|2=
  
 
{{API table/row
 
{{API table/row
|[[parallel.waitForAny]](function1, function2, ...)|{{type|nil}}
+
|[[parallel.waitForAny]]({{type|function}} function1, {{type|function}} function2, ...)
 +
|{{type|number}} stoppedFunction
 
|Runs all the functions at the same time, and stops when any of them returns.
 
|Runs all the functions at the same time, and stops when any of them returns.
 
|odd}}
 
|odd}}
  
 
{{API table/row
 
{{API table/row
|[[parallel.waitForAll]](function1, function2, ...)|{{type|nil}}
+
|[[parallel.waitForAll]]({{type|function}} function1, {{type|function}} function2, ...)
 +
|{{type|nil}}
 
|Runs all the functions at the same time, and stops when all of them have returned.
 
|Runs all the functions at the same time, and stops when all of them have returned.
 
|}}
 
|}}

Latest revision as of 20:29, 16 April 2014

Parallel is an API which allows you to multitask.

Functions are not actually executed simultaniously, but rather this API will automatically switch between them whenever they yield (eg whenever they call coroutine.yield(), or functions that call that - eg os.pullEvent() - or functions that call that, etc - basically, anything that causes the function to "pause").

Each function executed in "parallel" gets its own copy of the event queue, and so "event consuming" functions (again, mostly anything that causes the script to pause - eg sleep(), rednet.receive(), most of the turtle API, etc) can safely be used in one without affecting the event queue accessed by the other.

Grid disk.png  parallel (API)
Function Return values Description
parallel.waitForAny(function function1, function function2, ...) number stoppedFunction Runs all the functions at the same time, and stops when any of them returns.
parallel.waitForAll(function function1, function function2, ...) nil Runs all the functions at the same time, and stops when all of them have returned.