Merge remote-tracking branch 'jjyg/digmat' into 0.34.11-r4
Conflicts: Readme.rstdevelop
commit
237251ce0c
@ -0,0 +1,62 @@
|
|||||||
|
# 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)
|
Loading…
Reference in New Issue