Guest User

Untitled

a guest
Nov 16th, 2018
106
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 5.68 KB | None | 0 0
  1.  
  2. local tArgs = { ... }
  3. if #tArgs ~= 1 then
  4. print( "Usage: excavate <diameter>" )
  5. return
  6. end
  7.  
  8. -- Mine in a quarry pattern until we hit something we can't dig
  9. local size = tonumber( tArgs[1] )
  10. if size < 1 then
  11. print( "Excavate diameter must be positive" )
  12. return
  13. end
  14.  
  15. local depth = 0
  16. local unloaded = 0
  17. local collected = 0
  18.  
  19. local xPos,zPos = 0,0
  20. local xDir,zDir = 0,1
  21.  
  22. local goTo -- Filled in further down
  23. local refuel -- Filled in further down
  24.  
  25. local function unload()
  26. print( "Unloading items..." )
  27. for n=1,16 do
  28. unloaded = unloaded + turtle.getItemCount(n)
  29. turtle.select(n)
  30. turtle.drop()
  31. end
  32. collected = 0
  33. turtle.select(1)
  34. end
  35.  
  36. local function returnSupplies()
  37. local x,y,z,xd,zd = xPos,depth,zPos,xDir,zDir
  38. print( "Returning to surface..." )
  39. goTo( 0,0,0,0,-1 )
  40.  
  41.  
  42. unload()
  43. end
  44.  
  45. print( "Resuming mining..." )
  46. goTo( x,y,z,xd,zd )
  47. end
  48.  
  49. local function collect()
  50. local bFull = true
  51. local nTotalItems = 0
  52. for n=1,16 do
  53. local nCount = turtle.getItemCount(n)
  54. if nCount == 0 then
  55. bFull = false
  56. end
  57. nTotalItems = nTotalItems + nCount
  58. end
  59.  
  60. if nTotalItems > collected then
  61. collected = nTotalItems
  62. if math.fmod(collected + unloaded, 50) == 0 then
  63. print( "Mined "..(collected + unloaded).." items." )
  64. end
  65. end
  66.  
  67. if bFull then
  68. print( "No empty slots left." )
  69. return false
  70. end
  71. return true
  72. end
  73.  
  74.  
  75.  
  76.  
  77. local needed = ammount or (xPos + zPos + depth + 1)
  78. if turtle.getFuelLevel() < needed then
  79. print( needed )
  80. local fueled = false
  81. for n=1,16 do
  82. if turtle.getItemCount(n) > 0 then
  83. turtle.select(n)
  84. if turtle.refuel(1) then
  85. print( fuelLevel )
  86. while turtle.getItemCount(n) > 0 and turtle.getFuelLevel() < needed do
  87. turtle.refuel(1)
  88. print( fuelLevel )
  89. end
  90. if turtle.getFuelLevel() >= needed then
  91. turtle.select(1)
  92. return true
  93. end
  94. end
  95. end
  96. end
  97. turtle.select(1)
  98. return false
  99. end
  100.  
  101. return true
  102. end
  103.  
  104. local function tryForwards()
  105. if not refuel() then
  106. print( "Not enough Fuel" )
  107. returnSupplies()
  108. end
  109.  
  110. while not turtle.forward() do
  111. if turtle.detect() then
  112. if turtle.dig() then
  113. if not collect() then
  114. returnSupplies()
  115. end
  116. else
  117. return false
  118. end
  119. elseif turtle.attack() then
  120. if not collect() then
  121. returnSupplies()
  122. end
  123. else
  124. sleep( 0.5 )
  125. end
  126. end
  127.  
  128. xPos = xPos + xDir
  129. zPos = zPos + zDir
  130. return true
  131. end
  132.  
  133. local function tryDown()
  134.  
  135. returnSupplies()
  136. end
  137.  
  138. while not turtle.down() do
  139. if turtle.detectDown() then
  140. if turtle.digDown() then
  141. if not collect() then
  142. returnSupplies()
  143. end
  144. else
  145. return false
  146. end
  147. elseif turtle.attackDown() then
  148. if not collect() then
  149. returnSupplies()
  150. end
  151. else
  152. sleep( 0.5 )
  153. end
  154. end
  155.  
  156. depth = depth + 1
  157. if math.fmod( depth, 10 ) == 0 then
  158. print( "Descended "..depth.." metres." )
  159. end
  160.  
  161. return true
  162. end
  163.  
  164. local function turnLeft()
  165. turtle.turnLeft()
  166. xDir, zDir = -zDir, xDir
  167. end
  168.  
  169. local function turnRight()
  170. turtle.turnRight()
  171. xDir, zDir = zDir, -xDir
  172. end
  173.  
  174. function goTo( x, y, z, xd, zd )
  175. while depth > y do
  176. if turtle.up() then
  177. depth = depth - 1
  178. elseif turtle.digUp() or turtle.attackUp() then
  179. collect()
  180. else
  181. sleep( 0.5 )
  182. end
  183. end
  184.  
  185. if xPos > x then
  186. while xDir ~= -1 do
  187. turnLeft()
  188. end
  189. while xPos > x do
  190. if turtle.forward() then
  191. xPos = xPos - 1
  192. elseif turtle.dig() or turtle.attack() then
  193. collect()
  194. else
  195. sleep( 0.5 )
  196. end
  197. end
  198. elseif xPos < x then
  199. while xDir ~= 1 do
  200. turnLeft()
  201. end
  202. while xPos < x do
  203. if turtle.forward() then
  204. xPos = xPos + 1
  205. elseif turtle.dig() or turtle.attack() then
  206. collect()
  207. else
  208. sleep( 0.5 )
  209. end
  210. end
  211. end
  212.  
  213. if zPos > z then
  214. while zDir ~= -1 do
  215. turnLeft()
  216. end
  217. while zPos > z do
  218. if turtle.forward() then
  219. zPos = zPos - 1
  220. elseif turtle.dig() or turtle.attack() then
  221. collect()
  222. else
  223. sleep( 0.5 )
  224. end
  225. end
  226. elseif zPos < z then
  227. while zDir ~= 1 do
  228. turnLeft()
  229. end
  230. while zPos < z do
  231. if turtle.forward() then
  232. zPos = zPos + 1
  233. elseif turtle.dig() or turtle.attack() then
  234. collect()
  235. else
  236. sleep( 0.5 )
  237. end
  238. end
  239. end
  240.  
  241. while depth < y do
  242. if turtle.down() then
  243. depth = depth + 1
  244. elseif turtle.digDown() or turtle.attackDown() then
  245. collect()
  246. else
  247. sleep( 0.5 )
  248. end
  249. end
  250.  
  251. while zDir ~= zd or xDir ~= xd do
  252. turnLeft()
  253. end
  254. end
  255.  
  256. if not refuel() then
  257. print( "Out of Fuel" )
  258. return
  259. end
  260.  
  261. print( "Excavating..." )
  262.  
  263. local reseal = false
  264. turtle.select(1)
  265. if turtle.digDown() then
  266. reseal = true
  267. end
  268.  
  269. local alternate = 0
  270. local done = false
  271. while not done do
  272. for n=1,size do
  273. for m=1,size-1 do
  274. if not tryForwards() then
  275. done = true
  276. break
  277. end
  278. end
  279. if done then
  280. break
  281. end
  282. if n<size then
  283. if math.fmod(n + alternate,2) == 0 then
  284. turnLeft()
  285. if not tryForwards() then
  286. done = true
  287. break
  288. end
  289. turnLeft()
  290. else
  291. turnRight()
  292. if not tryForwards() then
  293. done = true
  294. break
  295. end
  296. turnRight()
  297. end
  298. end
  299. end
  300. if done then
  301. break
  302. end
  303.  
  304. if size > 1 then
  305. if math.fmod(size,2) == 0 then
  306. turnRight()
  307. else
  308. if alternate == 0 then
  309. turnLeft()
  310. else
  311. turnRight()
  312. end
  313. alternate = 1 - alternate
  314. end
  315. end
  316.  
  317. if not tryDown() then
  318. done = true
  319. break
  320. end
  321. end
  322.  
  323. print( "Returning to surface..." )
  324.  
  325. -- Return to where we started
  326. goTo( 0,0,0,0,-1 )
  327. unload()
  328. goTo( 0,0,0,0,1 )
  329.  
  330. -- Seal the hole
  331. if reseal then
  332. turtle.placeDown()
  333. end
  334.  
  335. print( "Mined "..(collected + unloaded).." items total." )
Add Comment
Please, Sign In to add comment