blob: 980b36a6305209efc7532dda8a1408198a4b274c [file] [log] [blame] [raw]
package li.cil.oc.api.network;
/**
* This type is used to deliver messages sent in a component network.
* <p/>
* We use an extra class to deliver messages to nodes to make the cancel logic
* more clear (returning a boolean can get annoying very fast).
*/
public interface Message {
/**
* The node that sent the message.
*
* @return the source node.
*/
Node source();
/**
* The name of this message.
*
* @return the name of the message.
*/
String name();
/**
* The values passed along in the message.
*
* @return the message data.
*/
Object[] data();
/**
* Stop further propagation of a broadcast message.
* <p/>
* This can be used to stop further distributing messages when either
* serving a message to a specific address and there are multiple nodes
* with that address, or when serving a broadcast message.
*/
void cancel();
}