Files
lakebane/src/engine/gameManager/ForgeManager.java
T

207 lines
7.4 KiB
Java
Raw Normal View History

2024-04-05 20:13:16 -04:00
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
// Magicbane Emulator Project © 2013 - 2022
// www.magicbane.com
package engine.gameManager;
import engine.loot.WorkOrder;
2024-04-10 16:06:09 -04:00
import engine.mbEnums;
2024-04-08 04:17:31 -04:00
import engine.objects.Item;
2024-04-10 16:47:02 -04:00
import engine.objects.ItemTemplate;
2024-04-07 22:21:47 -04:00
import engine.objects.PlayerCharacter;
2024-04-10 16:47:02 -04:00
import engine.powers.EffectsBase;
2024-04-07 22:28:07 -04:00
import org.pmw.tinylog.Logger;
2024-04-05 20:13:16 -04:00
2024-04-08 04:17:31 -04:00
import java.util.HashMap;
2024-04-05 20:13:16 -04:00
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.DelayQueue;
import java.util.concurrent.atomic.AtomicInteger;
public enum ForgeManager implements Runnable {
FORGE_MANAGER;
2024-04-07 22:15:06 -04:00
private static final BlockingQueue<WorkOrder> workOrders = new DelayQueue();
2024-04-06 07:26:17 -04:00
public static final AtomicInteger wordOrderCounter = new AtomicInteger(0);
2024-04-08 04:17:31 -04:00
public static HashMap<Item, WorkOrder> oven = new HashMap<Item, WorkOrder>();
2024-04-05 20:13:16 -04:00
@Override
public void run() {
while (true) {
try {
2024-04-06 07:26:17 -04:00
WorkOrder workOrder = workOrders.take();
2024-04-05 20:13:16 -04:00
2024-04-08 17:15:56 -04:00
// Completed or canceled work orders are not re-enqueued
if (workOrder.runCanceled || workOrder.runCompleted)
continue;
2024-04-08 17:56:51 -04:00
// Create negative ID items to add to collections
2024-04-05 20:13:16 -04:00
for (int i = 0; i < workOrder.slotCount; ++i) {
// Create workOrder items; one for each slot
// assigned to this workOrder.
// if Prefix and suffix are null random roll item
// otherwise roll what was asked for
2024-04-10 18:01:27 -04:00
workOrder.total_produced = workOrder.total_produced + 1;
2024-04-05 20:13:16 -04:00
}
2024-04-08 17:06:42 -04:00
Logger.info("item forged:" + workOrder.workOrderID + " (" + workOrder.total_produced + "/" + workOrder.total_to_produce + ")");
2024-04-08 17:02:20 -04:00
2024-04-08 13:06:22 -04:00
if (workOrder.total_produced >= workOrder.total_to_produce) {
2024-04-05 20:13:16 -04:00
2024-04-08 15:58:48 -04:00
Logger.info("Workorder has completed: " + workOrder.workOrderID);
2024-04-05 20:13:16 -04:00
workOrder.runCompleted = true;
2024-04-08 04:37:27 -04:00
workOrder.vendor.workOrders.remove(workOrder);
2024-04-05 20:13:16 -04:00
continue;
}
2024-04-10 18:01:27 -04:00
// Persist current items that are cooking
// after removing the negative id item from all collections.
// Add new item to the vendors inventory
2024-04-05 20:13:16 -04:00
// Resubmit workOrder
2024-04-08 15:58:48 -04:00
workOrder.completionTime = System.currentTimeMillis() + workOrder.rollingDuration;
2024-04-07 23:00:37 -04:00
workOrders.add(workOrder);
2024-04-05 20:13:16 -04:00
} catch (InterruptedException e) {
e.printStackTrace();
}
}
2024-04-07 22:15:06 -04:00
}
2024-04-05 20:13:16 -04:00
2024-04-07 22:53:41 -04:00
public static void start() {
2024-04-08 16:26:29 -04:00
Thread forgeManager;
forgeManager = new Thread(FORGE_MANAGER);
2024-04-07 22:53:41 -04:00
2024-04-08 16:26:29 -04:00
forgeManager.setName("Forge Manager");
forgeManager.start();
2024-04-07 22:53:41 -04:00
}
2024-04-07 22:15:06 -04:00
public static void submit(WorkOrder workOrder) {
2024-04-08 17:42:47 -04:00
2024-04-07 22:15:06 -04:00
workOrder.workOrderID = wordOrderCounter.incrementAndGet();
2024-04-07 23:21:35 -04:00
workOrder.completionTime = System.currentTimeMillis() + workOrder.rollingDuration;
2024-04-08 17:42:47 -04:00
workOrder.slotCount = calcAvailableSlots(workOrder);
2024-04-10 16:06:09 -04:00
workOrder.rollingDuration = ForgeManager.calcRollingDuration(workOrder);
2024-04-07 22:31:58 -04:00
2024-04-10 16:47:02 -04:00
// Cost to execute this workOrder
workOrder.production_cost = calcProductionCost(workOrder);
2024-04-11 13:46:24 -04:00
// Set total cost for this production run
2024-04-12 15:41:15 -04:00
workOrder.production_cost_total.putAll(workOrder.production_cost);
2024-04-12 15:48:25 -04:00
workOrder.production_cost_total.forEach((key, value) -> workOrder.production_cost_total.compute(key, (k, v) -> v * workOrder.total_to_produce));
2024-04-10 16:47:02 -04:00
2024-04-08 13:15:40 -04:00
// Single item rolls are total_to_produce of 0;
2024-04-07 22:53:41 -04:00
2024-04-08 16:49:19 -04:00
if (workOrder.slotCount > 0 && workOrder.total_to_produce == 0)
2024-04-08 13:15:40 -04:00
workOrder.slotCount = 1;
2024-04-07 22:31:58 -04:00
2024-04-08 17:56:51 -04:00
// Create negative ID items to add to collections
for (int i = 0; i < workOrder.slotCount; ++i) {
// Create workOrder items; one for each slot
// assigned to this workOrder.
2024-04-08 16:42:44 -04:00
2024-04-08 17:56:51 -04:00
// if Prefix and suffix are null random roll item
// otherwise roll what was asked for
2024-04-10 18:01:27 -04:00
workOrder.total_produced = workOrder.total_produced + 1;
2024-04-08 17:56:51 -04:00
}
Logger.info(workOrder.toString());
2024-04-08 04:37:27 -04:00
workOrder.vendor.workOrders.add(workOrder);
2024-04-07 22:15:06 -04:00
workOrders.add(workOrder);
2024-04-05 20:13:16 -04:00
}
2024-04-07 22:15:06 -04:00
2024-04-07 22:21:47 -04:00
public static boolean validate(PlayerCharacter playerCharacter, WorkOrder workOrder) {
2024-04-08 16:26:56 -04:00
2024-04-08 17:52:35 -04:00
// use Warehouse.caclulateOverdraft(workorder) method
2024-04-07 22:21:47 -04:00
return true;
}
2024-04-07 23:21:35 -04:00
public static long calcRollingDuration(WorkOrder workOrder) {
2024-04-12 16:43:22 -04:00
float rollingDuration;
rollingDuration = workOrder.vendor.getBuilding().getRank() * 5L + 40;
rollingDuration *= 60000;
rollingDuration *= Float.parseFloat(ConfigManager.MB_PRODUCTION_RATE.getValue());
2024-04-10 17:22:45 -04:00
ItemTemplate template = ItemTemplate.templates.get(workOrder.templateID);
2024-04-07 23:21:35 -04:00
// Bane circles
2024-04-10 17:22:45 -04:00
if (template.item_bane_rank > 0)
2024-04-12 16:43:22 -04:00
rollingDuration = (long) template.item_bane_rank * 60 * 60 * 3 * 1000 * Float.parseFloat(ConfigManager.MB_PRODUCTION_RATE.getValue());
2024-04-07 23:21:35 -04:00
2024-04-12 16:43:22 -04:00
return (long) rollingDuration;
2024-04-07 23:21:35 -04:00
}
2024-04-08 13:06:22 -04:00
2024-04-08 17:40:38 -04:00
public static int calcAvailableSlots(WorkOrder workOrder) {
2024-04-08 13:06:22 -04:00
2024-04-10 17:22:45 -04:00
// Slots available in a forge are based on the npc rank
2024-04-08 13:06:22 -04:00
int availableSlots = workOrder.vendor.getRank();
2024-04-10 17:22:45 -04:00
// Slots currently used up by the npc workOrders
2024-04-08 13:10:23 -04:00
for (WorkOrder npcWorkOrder : workOrder.vendor.workOrders)
availableSlots = availableSlots - npcWorkOrder.slotCount;
2024-04-08 13:06:22 -04:00
2024-04-10 17:22:45 -04:00
// Slot count override for single item production
if (workOrder.total_to_produce == 0 && availableSlots > 1)
availableSlots = 1;
2024-04-08 13:06:22 -04:00
return availableSlots;
}
2024-04-10 16:06:09 -04:00
public static HashMap<mbEnums.ResourceType, Integer> calcProductionCost(WorkOrder workOrder) {
2024-04-10 16:47:02 -04:00
2024-04-10 17:22:45 -04:00
// Calculate the production cost for a single run of this workOrder
2024-04-10 16:06:09 -04:00
HashMap<mbEnums.ResourceType, Integer> production_cost = new HashMap<>();
2024-04-10 16:47:02 -04:00
ItemTemplate template = ItemTemplate.templates.get(workOrder.templateID);
// Add gold and resource costs from template
production_cost.put(mbEnums.ResourceType.GOLD, template.item_value);
production_cost.putAll(template.item_resource_cost);
// Calculate cost of prefix and suffix
if (workOrder.prefixToken != 0) {
EffectsBase prefix = PowersManager.getEffectByToken(workOrder.prefixToken);
EffectsBase prefixValue = PowersManager.getEffectByIDString(prefix.getIDString() + 'A');
production_cost.putAll(prefixValue.getResourcesForEffect());
}
if (workOrder.suffixToken != 0) {
EffectsBase suffix = PowersManager.getEffectByToken(workOrder.suffixToken);
EffectsBase suffixValue = PowersManager.getEffectByIDString(suffix.getIDString() + 'A');
production_cost.putAll(suffixValue.getResourcesForEffect());
}
2024-04-10 16:06:09 -04:00
return production_cost;
}
2024-04-05 20:13:16 -04:00
}