Reorganized scripts folder. Deleted digmat.rb because it's redundant with digSmart and it has a higher FPS impact.
parent
187ce3c58b
commit
0f5bbd5631
@ -1,62 +0,0 @@
|
||||
# dig a mineral vein/layer, add tiles as they are discovered
|
||||
|
||||
# reuses the dig mode (upstairs etc) of the selected tile
|
||||
|
||||
if df.cursor.x < 0
|
||||
puts "Place the game cursor on a tile to dig"
|
||||
throw :script_finished
|
||||
end
|
||||
|
||||
tile = df.map_tile_at(df.cursor)
|
||||
if tile.shape_basic != :Wall or tile.designation.hidden
|
||||
puts "Place the game cursor on an unmined, discovered tile"
|
||||
throw :script_finished
|
||||
end
|
||||
|
||||
def digmat_watch(tile, digmode, tilelist)
|
||||
# watch the tile, expand mining operations when dug out
|
||||
tilelist << [tile.x, tile.y, tile.z]
|
||||
if tilelist.length == 1
|
||||
df.onupdate_register_once("digmat", 10) {
|
||||
tilelist.dup.each { |x, y, z|
|
||||
t = df.map_tile_at(x, y, z)
|
||||
if t.shape_basic != :Wall
|
||||
digmat_around(t, digmode, tilelist)
|
||||
tilelist.delete [x, y, z]
|
||||
end
|
||||
}
|
||||
tilelist.empty?
|
||||
}
|
||||
end
|
||||
tilelist.uniq!
|
||||
end
|
||||
|
||||
def digmat_around(tile, digmode=tile.designation.dig, tilelist=[])
|
||||
digmode = :Default if digmode == :No
|
||||
[-1, 0, 1].each { |dz|
|
||||
next if digmode == :Default and dz != 0
|
||||
next if tile.z+dz < 1 or tile.z+dz > df.world.map.z_count-2
|
||||
[-1, 0, 1].each { |dy|
|
||||
next if tile.y+dy < 1 or tile.y+dy > df.world.map.y_count-2
|
||||
[-1, 0, 1].each { |dx|
|
||||
next if tile.x+dx < 1 or tile.x+dx > df.world.map.x_count-2
|
||||
ntile = tile.offset(dx, dy, dz)
|
||||
next if not ntile
|
||||
next if ntile.designation.hidden
|
||||
next if ntile.designation.dig != :No
|
||||
next if ntile.shape_basic != :Wall
|
||||
next if not ntile.mat_info === tile.mat_info
|
||||
|
||||
# ignore damp/warm stone walls
|
||||
next if [-1, 0, 1].find { |ddy| [-1, 0, 1].find { |ddx|
|
||||
t = ntile.offset(ddx, ddy) and t.designation.flow_size > 1
|
||||
} }
|
||||
|
||||
ntile.dig(digmode)
|
||||
digmat_watch(ntile, digmode, tilelist)
|
||||
}
|
||||
}
|
||||
}
|
||||
end
|
||||
|
||||
digmat_around(tile)
|
@ -1,17 +1,17 @@
|
||||
--growthbug: units only grow when the current tick is 0 mod 10, so only 1/10 units will grow naturally. this script periodically sets the birth time of each unit so that it will grow
|
||||
--to run periodically, use "repeat -time 2 months -command growthBug now". see repeat.lua for details
|
||||
--to run periodically, use "repeat -time 2 months -command fix/growthBug now". see repeat.lua for details
|
||||
-- author expwnent
|
||||
|
||||
local args = {...}
|
||||
if args[1] ~= nil then
|
||||
print("growthbug usage")
|
||||
print(" growthbug")
|
||||
print("fix/growthbug usage")
|
||||
print(" fix/growthbug")
|
||||
print(" fix the growth bug for all units on the map")
|
||||
print(" growthbug help")
|
||||
print(" fix/growthbug help")
|
||||
print(" print this help message")
|
||||
print(" repeat -time [n] [years/months/ticks/days/etc] -command growthbug")
|
||||
print(" repeat -time [n] [years/months/ticks/days/etc] -command fix/growthbug")
|
||||
print(" run this script every n time units")
|
||||
print(" repeat -cancel growthbug")
|
||||
print(" repeat -cancel fix/growthbug")
|
||||
print(" stop automatically running this script")
|
||||
end
|
||||
|
Loading…
Reference in New Issue