Difference between revisions of "Turtle (API)"

From ComputerCraft Wiki
Jump to: navigation, search
(I just created articles for these two variances.)
(Adding the ComputerCraft version that introduced each function, accordingly with Changelog information. "?" for non-specified on that page, so the reader know that we don't know, instead of assuming that the feature was always present.)
Line 26: Line 26:
 
|[[turtle.craft]]({{type|number}} quantity)
 
|[[turtle.craft]]({{type|number}} quantity)
 
|Craft items using ingredients anywhere in the turtle's inventory and place results in the active slot. If a quantity is specified, it will craft only up to that many items, otherwise, it will craft as many of the items as possible.
 
|Craft items using ingredients anywhere in the turtle's inventory and place results in the active slot. If a quantity is specified, it will craft only up to that many items, otherwise, it will craft as many of the items as possible.
|
+
|1.4
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.forward]]()
 
|[[turtle.forward]]()
 
|Try to move the turtle forward
 
|Try to move the turtle forward
|
+
|?
 
|-  
 
|-  
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.back]]()
 
|[[turtle.back]]()
 
|Try to move the turtle backward
 
|Try to move the turtle backward
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.up]]()
 
|[[turtle.up]]()
 
|Try to move the turtle up
 
|Try to move the turtle up
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.down]]()
 
|[[turtle.down]]()
 
|Try to move the turtle down  
 
|Try to move the turtle down  
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.turnLeft]]()
 
|[[turtle.turnLeft]]()
 
|Turn the turtle left
 
|Turn the turtle left
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.turnRight]]()
 
|[[turtle.turnRight]]()
 
|Turn the turtle right
 
|Turn the turtle right
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.select]]({{type|number}} slotNum)
 
|[[turtle.select]]({{type|number}} slotNum)
 
|Make the turtle select slot <var>slotNum</var> (1 is top left, 16 (9 in 1.33 and earlier) is bottom right)
 
|Make the turtle select slot <var>slotNum</var> (1 is top left, 16 (9 in 1.33 and earlier) is bottom right)
|
+
|?
 
|-
 
|-
 
|{{type|number}} slot
 
|{{type|number}} slot
Line 71: Line 71:
 
|[[turtle.getItemCount]]([<nowiki/>{{type|number}} slotNum])
 
|[[turtle.getItemCount]]([<nowiki/>{{type|number}} slotNum])
 
|Counts how many items are in the currently selected slot or, if specified, <var>slotNum</var> slot
 
|Counts how many items are in the currently selected slot or, if specified, <var>slotNum</var> slot
|
+
|?
 
|-
 
|-
 
|{{type|number}} count
 
|{{type|number}} count
 
|[[turtle.getItemSpace]]([<nowiki/>{{type|number}} slotNum])
 
|[[turtle.getItemSpace]]([<nowiki/>{{type|number}} slotNum])
 
|Counts how many remaining items you need to fill the stack in the currently selected slot or, if specified, <var>slotNum</var> slot
 
|Counts how many remaining items you need to fill the stack in the currently selected slot or, if specified, <var>slotNum</var> slot
|
+
|?
 
|-
 
|-
 
|{{type|table}} data
 
|{{type|table}} data
Line 111: Line 111:
 
|[[turtle.dig]]()
 
|[[turtle.dig]]()
 
|Breaks the block in front. With hoe: tills the dirt in front of it.
 
|Breaks the block in front. With hoe: tills the dirt in front of it.
|
+
|?
 
|-{{row-lightyellow}}
 
|-{{row-lightyellow}}
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.digUp]]()
 
|[[turtle.digUp]]()
 
|Breaks the block above. With hoe: tills the dirt above it.
 
|Breaks the block above. With hoe: tills the dirt above it.
|
+
|?
 
|-{{row-lightyellow}}
 
|-{{row-lightyellow}}
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.digDown]]()
 
|[[turtle.digDown]]()
 
|Breaks the block below. With hoe: tills the dirt below it.
 
|Breaks the block below. With hoe: tills the dirt below it.
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
Line 131: Line 131:
 
|[[turtle.placeUp]]()
 
|[[turtle.placeUp]]()
 
|Places a block of the selected slot above. Collects water or lava if the currently selected slot is an empty bucket.
 
|Places a block of the selected slot above. Collects water or lava if the currently selected slot is an empty bucket.
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.placeDown]]()
 
|[[turtle.placeDown]]()
 
|Places a block of the selected slot below. Collects water or lava if the currently selected slot is an empty bucket.
 
|Places a block of the selected slot below. Collects water or lava if the currently selected slot is an empty bucket.
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
 
|[[turtle.detect]]()
 
|[[turtle.detect]]()
 
|Detects if there is a block in front.  Does not detect mobs.
 
|Detects if there is a block in front.  Does not detect mobs.
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
 
|[[turtle.detectUp]]()
 
|[[turtle.detectUp]]()
 
|Detects if there is a block above
 
|Detects if there is a block above
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
 
|[[turtle.detectDown]]()
 
|[[turtle.detectDown]]()
 
|Detects if there is a block below
 
|Detects if there is a block below
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success, {{type|table}} data/{{type|string}} error message
 
|{{type|boolean}} success, {{type|table}} data/{{type|string}} error message
Line 171: Line 171:
 
|[[turtle.compare]]()
 
|[[turtle.compare]]()
 
|Detects if the block in front is the same as the one in the currently selected slot
 
|Detects if the block in front is the same as the one in the currently selected slot
|
+
|1.31
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
 
|[[turtle.compareUp]]()
 
|[[turtle.compareUp]]()
 
|Detects if the block above is the same as the one in the currently selected slot
 
|Detects if the block above is the same as the one in the currently selected slot
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
 
|[[turtle.compareDown]]()
 
|[[turtle.compareDown]]()
 
|Detects if the block below is the same as the one in the currently selected slot
 
|Detects if the block below is the same as the one in the currently selected slot
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} result
 
|{{type|boolean}} result
Line 191: Line 191:
 
|[[turtle.drop]]([<nowiki></nowiki>{{type|number}} count])
 
|[[turtle.drop]]([<nowiki></nowiki>{{type|number}} count])
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e in front of the turtle) it will try to place into the inventory, returning false if the inventory is full.
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e in front of the turtle) it will try to place into the inventory, returning false if the inventory is full.
|
+
|?
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.drop|turtle.dropUp]]([<nowiki></nowiki>{{type|number}} count])
 
|[[turtle.drop|turtle.dropUp]]([<nowiki></nowiki>{{type|number}} count])
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e above the turtle) it will try to place into the inventory, returning false if the inventory is full.  
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e above the turtle) it will try to place into the inventory, returning false if the inventory is full.  
|
+
|1.4
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success
 
|[[turtle.drop|turtle.dropDown]]([<nowiki></nowiki>{{type|number}} count])
 
|[[turtle.drop|turtle.dropDown]]([<nowiki></nowiki>{{type|number}} count])
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e below the turtle) it will try to place into the inventory, returning false if the inventory is full. If above a furnace, will place item in the top slot.
 
|Drops all items in the selected slot, or specified, drops <var>count</var> items.<br />[>= 1.4 only:] If there is a inventory on the side (i.e below the turtle) it will try to place into the inventory, returning false if the inventory is full. If above a furnace, will place item in the top slot.
|
+
|1.4
 
|-
 
|-
 
|{{type|boolean}} success
 
|{{type|boolean}} success

Revision as of 23:17, 21 April 2015

The Turtle API is used to work with your Turtles.

Key

Color Turtles that can perform this
White All
Green Crafty
Yellow Mining, Felling, Digging, Farming
Red Any tool

API

Return Method name Description Min version
boolean success turtle.craft(number quantity) Craft items using ingredients anywhere in the turtle's inventory and place results in the active slot. If a quantity is specified, it will craft only up to that many items, otherwise, it will craft as many of the items as possible. 1.4
boolean success turtle.forward() Try to move the turtle forward ?
boolean success turtle.back() Try to move the turtle backward ?
boolean success turtle.up() Try to move the turtle up ?
boolean success turtle.down() Try to move the turtle down ?
boolean success turtle.turnLeft() Turn the turtle left ?
boolean success turtle.turnRight() Turn the turtle right ?
boolean success turtle.select(number slotNum) Make the turtle select slot slotNum (1 is top left, 16 (9 in 1.33 and earlier) is bottom right) ?
number slot turtle.getSelectedSlot() Indicates the currently selected inventory slot 1.6
number count turtle.getItemCount([number slotNum]) Counts how many items are in the currently selected slot or, if specified, slotNum slot ?
number count turtle.getItemSpace([number slotNum]) Counts how many remaining items you need to fill the stack in the currently selected slot or, if specified, slotNum slot ?
table data turtle.getItemDetail([number slotNum]) Returns the ID string, count and damage values of currently selected slot or, if specified, slotNum slot 1.64
boolean success turtle.equipLeft() Attempts to equip an item in the current slot to the turtle's left side, switching the previously equipped item back into the inventory 1.6
boolean success turtle.equipRight() Attempts to equip an item in the current slot to the turtle's right side, switching the previously equipped item back into the inventory 1.6
boolean success turtle.attack() Attacks in front of the turtle. 1.4
boolean success turtle.attackUp() Attacks above the turtle. 1.4
boolean success turtle.attackDown() Attacks under the turtle. 1.4
boolean success turtle.dig() Breaks the block in front. With hoe: tills the dirt in front of it. ?
boolean success turtle.digUp() Breaks the block above. With hoe: tills the dirt above it. ?
boolean success turtle.digDown() Breaks the block below. With hoe: tills the dirt below it. ?
boolean success turtle.place([string signText]) Places a block of the selected slot in front. Engrave signText on signs if provided. Collects water or lava if the currently selected slot is an empty bucket. 1.4
boolean success turtle.placeUp() Places a block of the selected slot above. Collects water or lava if the currently selected slot is an empty bucket. ?
boolean success turtle.placeDown() Places a block of the selected slot below. Collects water or lava if the currently selected slot is an empty bucket. ?
boolean result turtle.detect() Detects if there is a block in front. Does not detect mobs. ?
boolean result turtle.detectUp() Detects if there is a block above ?
boolean result turtle.detectDown() Detects if there is a block below ?
boolean success, table data/string error message turtle.inspect() Returns the ID string and metadata of the block in front of the Turtle 1.64
boolean success, table data/string error message turtle.inspectUp() Returns the ID string and metadata of the block above the Turtle 1.64
boolean success, table data/string error message turtle.inspectDown() Returns the ID string and metadata of the block below the Turtle 1.64
boolean result turtle.compare() Detects if the block in front is the same as the one in the currently selected slot 1.31
boolean result turtle.compareUp() Detects if the block above is the same as the one in the currently selected slot ?
boolean result turtle.compareDown() Detects if the block below is the same as the one in the currently selected slot ?
boolean result turtle.compareTo(number slot) Compare the current selected slot and the given slot to see if the items are the same. Returns true if they are the same, false if not. 1.4
boolean success turtle.drop([number count]) Drops all items in the selected slot, or specified, drops count items.
[>= 1.4 only:] If there is a inventory on the side (i.e in front of the turtle) it will try to place into the inventory, returning false if the inventory is full.
?
boolean success turtle.dropUp([number count]) Drops all items in the selected slot, or specified, drops count items.
[>= 1.4 only:] If there is a inventory on the side (i.e above the turtle) it will try to place into the inventory, returning false if the inventory is full.
1.4
boolean success turtle.dropDown([number count]) Drops all items in the selected slot, or specified, drops count items.
[>= 1.4 only:] If there is a inventory on the side (i.e below the turtle) it will try to place into the inventory, returning false if the inventory is full. If above a furnace, will place item in the top slot.
1.4
boolean success turtle.suck([number amount]) Picks up an item stack of any number, from the ground or an inventory in front of the turtle, then places it in the selected slot. If the turtle can't pick up the item, the function returns false. amount parameter requires ComputerCraft 1.6 or later. 1.4
boolean success turtle.suckUp([number amount]) Picks up an item stack of any number, from the ground or an inventory above the turtle, then places it in the selected slot. If the turtle can't pick up the item, the function returns false. amount parameter requires ComputerCraft 1.6 or later. 1.4
boolean success turtle.suckDown([number amount]) Picks up an item stack of any number, from the ground or an inventory below the turtle, then places it in the selected slot. If the turtle can't pick up the item, the function returns false. amount parameter requires ComputerCraft 1.6 or later. 1.4
boolean success turtle.refuel([number quantity]) If the current selected slot contains a fuel item, it will consume it to give the turtle the ability to move.
Added in 1.4 and is only needed in needfuel mode. If the current slot doesn't contain a fuel item, it returns false. Fuel values for different items can be found at Turtle.refuel#Fuel_Values. If a quantity is specified, it will refuel only up to that many items, otherwise, it will consume all the items in the slot.
1.4
number fuel turtle.getFuelLevel() Returns the current fuel level of the turtle, this is the number of blocks the turtle can move.
If turtleNeedFuel = 0 then it returns "unlimited".
1.4
number fuel turtle.getFuelLimit() Returns the maximum amount of fuel a turtle can store - by default, 20,000 for regular turtles, 100,000 for advanced.
If turtleNeedFuel = 0 then it returns "unlimited".
1.6
boolean success turtle.transferTo(number slot [, number quantity]) Transfers quantity items from the selected slot to slot. If quantity isn't specified, will attempt to transfer everything in the selected slot to slot. 1.45

Trivia: During the 1.4 beta, turtle.getFuelLevel() in softcore (that is now turtleneedsfuel = 0) returned 9000.