Difference between revisions of "Rednet.receive"
(Changing float to number) |
Bomb Bloke (Talk | contribs) (A long planned rewrite) |
||
Line 2: | Line 2: | ||
{{Function | {{Function | ||
|name=rednet.receive | |name=rednet.receive | ||
− | |args={{type|number}} | + | |args=[<nowiki/> [<nowiki/>{{type|string}} protocolFilter, ] {{type|number}} timeout] |
− | |returns=senderID, message, | + | |returns={{type|number}} senderID, {{type|string}} message, {{type|string}} protocol |
|api=rednet | |api=rednet | ||
|addon=ComputerCraft | |addon=ComputerCraft | ||
− | |desc=Waits for | + | |desc=Waits for ''timeout'' seconds, or until a [[rednet_message_(event)|rednet_message]] event is found in the event queue (with a matching [[Rednet (API)#Protocols|protocol]], if specified). The system must have a [[modem]] that's been [[rednet.open|readied for rednet usage]] in order for this to function; messages may then be sent to it from remote systems via [[rednet.send|rednet.send()]] / [[rednet.broadcast|rednet.broadcast()]].<br><br> |
+ | |||
+ | Due to the nature of how [[os.pullEvent|events are pulled]], using this function will generally cause the system to discard and ignore any other events that occur until the message is received or the time out ends (though Ctrl+T can generally be used to terminate it, if need be). Likewise, if the system is not specifically listening when a given message is sent, chances are high that another "event-eating" function (eg a [[turtle (API)|turtle movement call]] or most anything else that pauses code execution, such as "sleep") will discard it, making it impossible to "receive". This issue can be bypassed using [[Coroutine (API)|co-routines]] - notably, the [[parallel (API)|parallel API]] offers easy work-arounds.<br><br> | ||
+ | |||
+ | If a time out value is specified and reached, then {{type|nil}} is returned. Note that protocols are only supported by ComputerCraft 1.6 or later - versions prior returned the distance between the sender and receiver instead (information that can still be gained by inspecting [[modem_message_(event)|modem_message]] events directly, but which may not be "accurate" depending on whether any [[Repeat (program)|Rednet repeaters]] are active on your network).<br><br> | ||
+ | |||
+ | This command listens on modem channel numbers equal to the system's own [[os.getComputerID|ID]] and 65535 (the latter of which is used for broadcasts). More channels may be opened and listened on by dealing with your modems directly via [[Modem (API)|their own API]]. | ||
|examples= | |examples= | ||
{{Example | {{Example | ||
− | |desc=Waits | + | |desc=Prints 2 - 4 messages, depending on what's received. |
− | + | |code=-- Waits until someone sends a message to this computer, then displays it. | |
− | + | local senderId, message, protocol = rednet.receive() | |
+ | print(message) | ||
+ | |||
+ | -- Waits five seconds or until someone sends a message to this computer, then displays it. | ||
+ | senderId, message, protocol = rednet.receive(5) | ||
+ | print(message) | ||
+ | |||
+ | -- Waits until someone sends a message to this computer with a protocol of "futons", then displays it. | ||
+ | senderId, message, protocol = rednet.receive("futons") | ||
+ | print(message) | ||
+ | |||
+ | -- Waits five seconds or until someone sends a message to this computer with a protocol of "futons", then displays it. | ||
+ | senderId, message, protocol = rednet.receive("futons",5) | ||
+ | print(message) | ||
}} | }} | ||
}} | }} | ||
+ | |||
+ | {{RednetAPIFunctions}} | ||
[[Category:API_Functions]] | [[Category:API_Functions]] |
Revision as of 06:33, 6 June 2014
Function rednet.receive | |
Waits for timeout seconds, or until a rednet_message event is found in the event queue (with a matching protocol, if specified). The system must have a modem that's been readied for rednet usage in order for this to function; messages may then be sent to it from remote systems via rednet.send() / rednet.broadcast(). Due to the nature of how events are pulled, using this function will generally cause the system to discard and ignore any other events that occur until the message is received or the time out ends (though Ctrl+T can generally be used to terminate it, if need be). Likewise, if the system is not specifically listening when a given message is sent, chances are high that another "event-eating" function (eg a turtle movement call or most anything else that pauses code execution, such as "sleep") will discard it, making it impossible to "receive". This issue can be bypassed using co-routines - notably, the parallel API offers easy work-arounds. If a time out value is specified and reached, then nil is returned. Note that protocols are only supported by ComputerCraft 1.6 or later - versions prior returned the distance between the sender and receiver instead (information that can still be gained by inspecting modem_message events directly, but which may not be "accurate" depending on whether any Rednet repeaters are active on your network). | |
Syntax | rednet.receive([ [string protocolFilter, ] number timeout]) |
Returns | number senderID, string message, string protocol |
Part of | ComputerCraft |
API | rednet |
Examples
Rednet API Functions |
---|
rednet.open - rednet.close - rednet.send - rednet.broadcast - rednet.receive - rednet.isOpen - rednet.host - rednet.unhost - rednet.lookup |