-
Notifications
You must be signed in to change notification settings - Fork 431
Component RedstoneInMotion
Vexatos edited this page Jul 13, 2014
·
5 revisions
For those that don't like images: the wiki has moved to a new place, http://ocdoc.cil.li/.
This wiki will no longer be updated.
This component represents a Carriage Controller block from the Redstone in Motion mod.
Important: this component is only available if OpenComponents is also installed!
Component name: carriage
.
Callbacks:
-
getAnchored(): boolean
Gets whether the controller should remain where it is when moving a carriage. -
setAnchored(value: boolean): boolean
Sets whether the controller should remain where it is when moving a carriage. Returns the new value. -
move(direction: string or number[, simulate: boolean]): boolean
Tells the controller to try to move a carriage. The direction can either be a string indicating a direction or one of the[[sides|API/Sides]]
constants. You can optionally specify whether to only simulate a move, which defaults to false. Returnstrue
if the command was relayed successfully.
This function does not return the actual results of the move.
Due to technical limitations the results are asynchronously fed back to the computer as a signal with the namecarriage_moved
. It has the signaturesuccess: result[, reason: string]
, wherereason
is an error string if the move failed. This is because the computer that triggers the move may be moved as well, meaning it has to be persisted, which is only possible while it is in a yielded state.
Possible string values for direction are: negy, posy, negz, posz, negx, posx and down, up, north, south, west, east. -
simulate(direction: string or number): boolean
Likemove(direction, true)
.
Example use:
local component = require("component")
local event = require("event")
local sides = require("sides")
local cc = component.carriage -- get primary carriage controller
cc.move("up")
local _, _, result, reason, x, y, z = event.pull("carriage_moved")
if not result then
if x then
print(reason)
print("Block location: " .. x .. ", " .. y .. ", " .. z)
else
print(reason)
end
end
-- using the sides table:
cc.simulate(sides.west)