app tweaks

This commit is contained in:
kepler155c
2018-11-08 22:38:04 -05:00
parent 85b1d1d52e
commit 5e744be252
3 changed files with 91 additions and 36 deletions

View File

@@ -1,12 +1,13 @@
_G.requireInjector(_ENV)
local Point = require('point')
local Util = require('util')
local Point = require('point')
local Util = require('util')
local device = _G.device
local fs = _G.fs
local os = _G.os
local turtle = _G.turtle
local device = _G.device
local fs = _G.fs
local os = _G.os
local peripheral = _G.peripheral
local turtle = _G.turtle
local CONFIG_FILE = 'usr/config/farm'
@@ -29,12 +30,25 @@ local crops = Util.readTable(CONFIG_FILE) or {
['minecraft:melon_block'] = { action = 'smash' },
['minecraft:pumpkin'] = { action = 'smash' },
['minecraft:chest'] = { action = 'drop' },
['minecraft:cactus'] = { action = 'bump' },
}
if not fs.exists(CONFIG_FILE) then
Util.writeTable(CONFIG_FILE, crops)
end
local retain = Util.transpose {
"minecraft:diamond_pickaxe",
"plethora:module:2",
"plethora:module:3",
}
for _, v in pairs(crops) do
if v.seed then
retain[v.seed] = true
end
end
local function scan()
local blocks = scanner.scan()
local summed = turtle.getSummedInventory()
@@ -47,29 +61,35 @@ local function scan()
end
end
Util.filterInplace(blocks, function(v)
v.action = crops[v.name] and crops[v.name].action
Util.filterInplace(blocks, function(b)
b.action = crops[b.name] and crops[b.name].action
if v.action == 'bash' then
return v.y == 0
if b.action == 'bash' then
return b.y == 0
end
if v.action == 'drop' then
return doDropOff and v.y == -1
if b.action == 'drop' then
return doDropOff and b.y == -1
end
if v.action == 'smash' then
return v.y == -1
if b.action == 'smash' then
return b.y == -1
end
if v.action == 'pick' then
return v.y == 0 and v.state.age == 2
if b.action == 'pick' then
return b.y == 0 and b.state.age == 2
end
return v.action == 'plant' and
v.metadata == crops[v.name].mature and
v.y == -1
if b.action == 'bump' then
return b.y == 0
end
return b.action == 'plant' and
b.metadata == crops[b.name].mature and
b.y == -1
end)
local harvestCount = 0
for _,v in pairs(blocks) do
if v.action ~= 'drop' then
for _,b in pairs(blocks) do
b.x = b.x + turtle.point.x
b.y = b.y + turtle.point.y
b.z = b.z + turtle.point.z
if b.action ~= 'drop' then
harvestCount = harvestCount + 1
end
end
@@ -79,7 +99,6 @@ end
local function harvest(blocks)
turtle.equip('right', 'minecraft:diamond_pickaxe')
turtle.setPoint({ x = 0, y = 0, z = 0, heading = turtle.point.heading })
turtle.select(1)
local dropped
@@ -87,25 +106,58 @@ local function harvest(blocks)
Point.eachClosest(turtle.point, blocks, function(b)
if b.action == 'bash' then
turtle.digForwardAt(b)
elseif b.action == 'drop' and not dropped then
if turtle._goto(Point.above(b)) then
turtle.eachFilledSlot(function(slot)
if not retain[slot.name] and not retain[slot.key] then
turtle.select(slot.index)
turtle.dropDown()
end
end)
local summed = turtle.getSummedInventory()
for k,v in pairs(summed) do
if v.count > 16 then
turtle.dropDown(k, v.count - 16)
end
end
dropped = true
turtle.condense()
turtle.select(1)
end
elseif b.action == 'smash' then
turtle.digDownAt(b)
elseif b.action == 'plant' then
if turtle.digDownAt(b) then
turtle.placeDown(crops[b.name].seed)
turtle.select(1)
end
elseif b.action == 'bump' then
if turtle.faceAgainst(b) then
turtle.equip('right', 'plethora:module:3')
local sensed = peripheral.call('right', 'sense')
turtle.equip('right', 'minecraft:diamond_pickaxe')
os.sleep(.25)
Util.filterInplace(sensed, function(s)
if s.displayName == 'item.tile.cactus' and Point.distance(b, s) < 6 then
s.ex = s.x
s.ez = s.z
s.x = Util.round(s.x) + turtle.point.x
s.z = Util.round(s.z) + turtle.point.z
s.y = -1
return true
end
end)
Point.eachClosest(turtle.point, sensed, function(s)
turtle.suckDownAt(s)
end)
turtle.select(1)
end
elseif b.action == 'pick' then
local h = Point.facings[b.state.facing].heading
local hi = Point.headings[(h + 2) % 4] -- opposite heading
@@ -126,6 +178,8 @@ local s, m = turtle.run(function()
local facing = scanner.getBlockMeta(0, 0, 0).state.facing
turtle.point.heading = Point.facings[facing].heading
print('Fuel: ' .. turtle.getFuelLevel())
--turtle.setPolicy('digOnly')
turtle.setMovementStrategy('goto')
repeat

View File

@@ -17,9 +17,9 @@ local retain = Util.transpose {
}
local config = {
animal = 'Cow',
max_cows = 15,
max_animals = 15,
}
Config.load('cows', config)
Config.load('rancher', config)
local sensor = device['plethora:sensor'] or
turtle.equip('right', 'plethora:module:3') and device['plethora:sensor'] or
@@ -50,7 +50,7 @@ local function turnOnWater()
end
end
local function getCowCount()
local function getAnimalCount()
local blocks = sensor.sense()
local grown = 0
@@ -114,8 +114,8 @@ local s, m = turtle.run(function()
turnOffWater()
repeat
local cowCount, xpCount = getCowCount()
if cowCount > config.max_cows then
local animalCount, xpCount = getAnimalCount()
if animalCount > config.max_animals then
turtle.setStatus('Butchering')
butcher()
elseif turtle.getItemCount('minecraft:wheat') == 0 then

View File

@@ -1,9 +1,12 @@
_G.requireInjector(_ENV)
local device = _G.device
local multishell = _G.multishell
if not device.wireless_modem then
error('Wireless modem is required')
end
requireInjector(getfenv(1))
local Event = require('event')
local GPS = require('gps')
local Socket = require('socket')
@@ -20,11 +23,10 @@ local mainPage = UI.Page({
y = 2,
height = 8,
menuItems = {
{ prompt = 'Add', event = 'add_location', help = 'Add a new location' },
{ prompt = 'Pickup', event = 'pickup', help = 'Pickup items from this location' },
{ prompt = 'Charge cell', event = 'charge', help = 'Recharge this cell' },
{ prompt = 'Refill', event = 'refill', help = 'Recharge this cell' },
{ prompt = 'Set drop off location', event = 'setPickup', help = 'Recharge this cell' },
{ prompt = 'Set recharge location', event = 'setRecharge', help = 'Recharge this cell' },
{ prompt = 'Clear', event = 'clear', help = 'Remove this location' },
},
}),
@@ -115,7 +117,7 @@ function refillPage:eventHandler(event)
text = UI.Text({ x = 3, y = 3, value = 'Quantity' }),
textEntry = UI.TextEntry({ x = 14, y = 3 })
})
dialog.eventHandler = function(self, event)
if event.type == 'accept' then
local l = tonumber(self.textEntry.value)
@@ -129,10 +131,10 @@ function refillPage:eventHandler(event)
end
return true
end
return UI.Dialog.eventHandler(self, event)
end
dialog.titleBar.title = item.name
dialog:setFocus(dialog.textEntry)
UI:setPage(dialog)
@@ -202,8 +204,7 @@ function mainPage:eventHandler(event)
UI:setPage(refillPage)
end
elseif event.type == 'pickup' or event.type == 'setPickup' or
event.type == 'setRecharge' or event.type == 'charge' or
elseif event.type == 'pickup' or event.type == 'setPickup' or
event.type == 'clear' then
local pt = getPoint()
if pt then