2015-08-15 00:43:50 -06:00
|
|
|
# convenient way to ban cooking categories of food
|
2015-10-23 22:10:15 -06:00
|
|
|
=begin
|
|
|
|
|
|
|
|
ban-cooking
|
|
|
|
===========
|
|
|
|
A more convenient way to ban cooking various categories of foods than the
|
|
|
|
kitchen interface. Usage: ``ban-cooking <type>``. Valid types are ``booze``,
|
2016-01-18 14:07:09 -07:00
|
|
|
``honey``, ``tallow``, ``oil``, ``seeds`` (non-tree plants with seeds),
|
2016-01-18 14:29:49 -07:00
|
|
|
``brew``, ``mill``, ``thread``, and ``milk``.
|
2015-10-23 22:10:15 -06:00
|
|
|
|
|
|
|
=end
|
2015-08-15 00:43:50 -06:00
|
|
|
|
2015-03-28 12:09:35 -06:00
|
|
|
already_banned = {}
|
|
|
|
kitchen = df.ui.kitchen
|
|
|
|
kitchen.item_types.length.times { |i|
|
|
|
|
already_banned[[kitchen.mat_types[i], kitchen.mat_indices[i], kitchen.item_types[i], kitchen.item_subtypes[i]]] = kitchen.exc_types[i] & 1
|
|
|
|
}
|
|
|
|
ban_cooking = lambda { |mat_type, mat_index, type|
|
|
|
|
subtype = -1
|
|
|
|
key = [mat_type, mat_index, type, subtype]
|
|
|
|
if already_banned[key]
|
|
|
|
next if already_banned[key] == 1
|
|
|
|
|
|
|
|
index = kitchen.mat_types.zip(kitchen.mat_indices, kitchen.item_types, kitchen.item_subtypes)
|
|
|
|
kitchen.exc_types[index] |= 1
|
|
|
|
already_banned[key] = 1
|
|
|
|
next
|
|
|
|
end
|
|
|
|
df.ui.kitchen.mat_types << mat_type
|
|
|
|
df.ui.kitchen.mat_indices << mat_index
|
|
|
|
df.ui.kitchen.item_types << type
|
|
|
|
df.ui.kitchen.item_subtypes << subtype
|
|
|
|
df.ui.kitchen.exc_types << 1
|
|
|
|
already_banned[key] = 1
|
|
|
|
}
|
|
|
|
|
|
|
|
$script_args.each do |arg|
|
|
|
|
case arg
|
|
|
|
when 'booze'
|
|
|
|
df.world.raws.plants.all.each_with_index do |p, i|
|
|
|
|
p.material.each_with_index do |m, j|
|
|
|
|
if m.flags[:ALCOHOL]
|
|
|
|
ban_cooking[j + DFHack::MaterialInfo::PLANT_BASE, i, :DRINK]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
df.world.raws.creatures.all.each_with_index do |c, i|
|
|
|
|
c.material.each_with_index do |m, j|
|
|
|
|
if m.flags[:ALCOHOL]
|
|
|
|
ban_cooking[j + DFHack::MaterialInfo::CREATURE_BASE, i, :DRINK]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
when 'honey'
|
|
|
|
# hard-coded in the raws of the mead reaction
|
|
|
|
honey = df.decode_mat('CREATURE:HONEY_BEE:HONEY')
|
|
|
|
ban_cooking[honey.mat_type, honey.mat_index, :LIQUID_MISC]
|
|
|
|
|
|
|
|
when 'tallow'
|
|
|
|
df.world.raws.creatures.all.each_with_index do |c, i|
|
|
|
|
c.material.each_with_index do |m, j|
|
|
|
|
if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('SOAP_MAT')
|
|
|
|
ban_cooking[j + DFHack::MaterialInfo::CREATURE_BASE, i, :GLOB]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
when 'oil'
|
|
|
|
df.world.raws.plants.all.each_with_index do |p, i|
|
|
|
|
p.material.each_with_index do |m, j|
|
|
|
|
if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('SOAP_MAT')
|
|
|
|
ban_cooking[j + DFHack::MaterialInfo::PLANT_BASE, i, :LIQUID_MISC]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
when 'seeds'
|
|
|
|
df.world.raws.plants.all.each do |p|
|
|
|
|
m = df.decode_mat(p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat).material
|
|
|
|
ban_cooking[p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat, :PLANT] if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('SEED_MAT')
|
|
|
|
|
|
|
|
if not p.flags[:TREE]
|
|
|
|
p.growths.each do |g|
|
|
|
|
m = df.decode_mat(g).material
|
|
|
|
ban_cooking[g.mat_type, g.mat_index, :PLANT_GROWTH] if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('SEED_MAT')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-01-18 14:07:09 -07:00
|
|
|
when 'brew'
|
|
|
|
df.world.raws.plants.all.each do |p|
|
|
|
|
m = df.decode_mat(p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat).material
|
|
|
|
ban_cooking[p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat, :PLANT] if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('DRINK_MAT')
|
|
|
|
|
|
|
|
p.growths.each do |g|
|
|
|
|
m = df.decode_mat(g).material
|
|
|
|
ban_cooking[g.mat_type, g.mat_index, :PLANT_GROWTH] if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('DRINK_MAT')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
when 'mill'
|
|
|
|
df.world.raws.plants.all.each do |p|
|
|
|
|
ban_cooking[p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat, :PLANT] if m.flags[:MILL]
|
|
|
|
end
|
|
|
|
|
|
|
|
when 'thread'
|
|
|
|
df.world.raws.plants.all.each do |p|
|
|
|
|
ban_cooking[p.material_defs.type_basic_mat, p.material_defs.idx_basic_mat, :PLANT] if m.flags[:THREAD]
|
|
|
|
end
|
|
|
|
|
2016-01-18 14:29:49 -07:00
|
|
|
when 'milk'
|
|
|
|
df.world.raws.creatures.all.each_with_index do |c, i|
|
|
|
|
c.material.each_with_index do |m, j|
|
|
|
|
if m.reaction_product and m.reaction_product.id and m.reaction_product.id.include?('CHEESE_MAT')
|
|
|
|
ban_cooking[j + DFHack::MaterialInfo::CREATURE_BASE, i, :LIQUID_MISC]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-03-28 12:09:35 -06:00
|
|
|
else
|
|
|
|
puts "ban-cooking booze - bans cooking of drinks"
|
|
|
|
puts "ban-cooking honey - bans cooking of honey bee honey"
|
|
|
|
puts "ban-cooking tallow - bans cooking of tallow"
|
|
|
|
puts "ban-cooking oil - bans cooking of oil"
|
|
|
|
puts "ban-cooking seeds - bans cooking of plants that have seeds (tree seeds don't count)"
|
2016-01-18 14:07:09 -07:00
|
|
|
puts "ban-cooking brew - bans cooking of plants that can be brewed into alcohol"
|
|
|
|
puts "ban-cooking mill - bans cooking of plants that can be milled into powder"
|
|
|
|
puts "ban-cooking thread - bans cooking of plants that can be turned into thread"
|
2016-01-18 14:29:49 -07:00
|
|
|
puts "ban-cooking milk - bans cooking of creature liquids that can be turned into cheese"
|
2015-03-28 12:09:35 -06:00
|
|
|
end
|
|
|
|
end
|