From a1533a166ae8a303c8f2141d8b91a5827d135e8b Mon Sep 17 00:00:00 2001 From: Iajret Date: Sun, 22 Oct 2023 15:46:30 +0300 Subject: [PATCH 1/3] free market no more --- tff_modular/modules/gmm_removal/cargo.dm | 60 ++++++++++++++++++++++++ tgstation.dme | 1 + 2 files changed, 61 insertions(+) create mode 100644 tff_modular/modules/gmm_removal/cargo.dm diff --git a/tff_modular/modules/gmm_removal/cargo.dm b/tff_modular/modules/gmm_removal/cargo.dm new file mode 100644 index 00000000000..4f7c230c2bb --- /dev/null +++ b/tff_modular/modules/gmm_removal/cargo.dm @@ -0,0 +1,60 @@ +//прячем заказ на маркет +/datum/supply_pack/imports/materials_market + special = TRUE + +//возвращаем стекло и железо (и пласталь) в покупки +/datum/supply_pack/materials/glass50 + name = "50 Glass Sheets" + desc = "Let some nice light in with fifty glass sheets!" + cost = CARGO_CRATE_VALUE * 2 + contains = list(/obj/item/stack/sheet/glass/fifty) + crate_name = "glass sheets crate" + +/datum/supply_pack/materials/iron50 + name = "50 Iron Sheets" + desc = "Any construction project begins with a good stack of fifty iron sheets!" + cost = CARGO_CRATE_VALUE * 2 + contains = list(/obj/item/stack/sheet/iron/fifty) + crate_name = "iron sheets crate" + +/datum/supply_pack/materials/plasteel20 + name = "20 Plasteel Sheets" + desc = "Reinforce the station's integrity with twenty plasteel sheets!" + cost = CARGO_CRATE_VALUE * 15 + contains = list(/obj/item/stack/sheet/plasteel/twenty) + crate_name = "plasteel sheets crate" + +/datum/supply_pack/materials/plasteel50 + name = "50 Plasteel Sheets" + desc = "For when you REALLY have to reinforce something." + cost = CARGO_CRATE_VALUE * 33 + contains = list(/obj/item/stack/sheet/plasteel/fifty) + crate_name = "plasteel sheets crate" + +//возвращаем статичные подверженные "эластичности" цены минералов +/datum/export/material/market + var/prices_by_material = list( + /datum/material/iron = CARGO_CRATE_VALUE * 0.01, + /datum/material/glass = CARGO_CRATE_VALUE * 0.01, + /datum/material/titanium = CARGO_CRATE_VALUE * 0.25, + /datum/material/silver = CARGO_CRATE_VALUE * 0.1, + /datum/material/gold = CARGO_CRATE_VALUE * 0.25, + /datum/material/uranium = CARGO_CRATE_VALUE * 0.2, + /datum/material/diamond = CARGO_CRATE_VALUE, + /datum/material/bluespace = CARGO_CRATE_VALUE * 0.6, + ) + +/datum/export/material/market/get_cost(obj/O, apply_elastic = FALSE) + ..() + //копипаста из /datum/export родителя чтобы заредефайнить цены нашего нового класса обратно назад. + var/obj/item/I = O + var/amount = get_amount(I) + if(!amount) + return 0 + if(k_elasticity != 0) + return round((prices_by_material[material_id]/k_elasticity) * (1 - NUM_E**(-1 * k_elasticity * amount))) + else + return round(cost * amount) + +/datum/export/material/market/bscrystal/New() + export_types =+ list(/obj/item/stack/ore/bluespace_crystal, /obj/item/stack/ore/bluespace_crystal/refined) diff --git a/tgstation.dme b/tgstation.dme index 06d64820e51..798c1d508e5 100644 --- a/tgstation.dme +++ b/tgstation.dme @@ -7837,6 +7837,7 @@ #include "tff_modular\modules\emotes\code\emotes.dm" #include "tff_modular\modules\emotes\code\laugh_datums.dm" #include "tff_modular\modules\emotes\code\scream_datums.dm" +#include "tff_modular\modules\gmm_removal\cargo.dm" #include "tff_modular\modules\hair\code\hair.dm" #include "tff_modular\modules\halloween-decor\halloween-craft.dm" #include "tff_modular\modules\halloween-decor\halloween-decor.dm" From 65e83f896bcc26721b3d5cbe060d0cd037bfa51c Mon Sep 17 00:00:00 2001 From: Iajret Date: Sun, 22 Oct 2023 16:04:24 +0300 Subject: [PATCH 2/3] oops --- tff_modular/modules/gmm_removal/cargo.dm | 3 --- 1 file changed, 3 deletions(-) diff --git a/tff_modular/modules/gmm_removal/cargo.dm b/tff_modular/modules/gmm_removal/cargo.dm index 4f7c230c2bb..a62de6d7355 100644 --- a/tff_modular/modules/gmm_removal/cargo.dm +++ b/tff_modular/modules/gmm_removal/cargo.dm @@ -55,6 +55,3 @@ return round((prices_by_material[material_id]/k_elasticity) * (1 - NUM_E**(-1 * k_elasticity * amount))) else return round(cost * amount) - -/datum/export/material/market/bscrystal/New() - export_types =+ list(/obj/item/stack/ore/bluespace_crystal, /obj/item/stack/ore/bluespace_crystal/refined) From 0ac47ad77da31e961d320fcc13bfc8fa88329a2c Mon Sep 17 00:00:00 2001 From: Iajret Date: Fri, 27 Oct 2023 22:19:00 +0300 Subject: [PATCH 3/3] Update cargo.dm --- tff_modular/modules/gmm_removal/cargo.dm | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/tff_modular/modules/gmm_removal/cargo.dm b/tff_modular/modules/gmm_removal/cargo.dm index a62de6d7355..bb0e560d954 100644 --- a/tff_modular/modules/gmm_removal/cargo.dm +++ b/tff_modular/modules/gmm_removal/cargo.dm @@ -1,8 +1,6 @@ -//прячем заказ на маркет /datum/supply_pack/imports/materials_market special = TRUE -//возвращаем стекло и железо (и пласталь) в покупки /datum/supply_pack/materials/glass50 name = "50 Glass Sheets" desc = "Let some nice light in with fifty glass sheets!" @@ -31,9 +29,8 @@ contains = list(/obj/item/stack/sheet/plasteel/fifty) crate_name = "plasteel sheets crate" -//возвращаем статичные подверженные "эластичности" цены минералов /datum/export/material/market - var/prices_by_material = list( + var/static/list/prices_by_material = list( /datum/material/iron = CARGO_CRATE_VALUE * 0.01, /datum/material/glass = CARGO_CRATE_VALUE * 0.01, /datum/material/titanium = CARGO_CRATE_VALUE * 0.25, @@ -44,9 +41,7 @@ /datum/material/bluespace = CARGO_CRATE_VALUE * 0.6, ) -/datum/export/material/market/get_cost(obj/O, apply_elastic = FALSE) - ..() - //копипаста из /datum/export родителя чтобы заредефайнить цены нашего нового класса обратно назад. +/datum/export/material/market/get_cost(obj/O, apply_elastic = TRUE) var/obj/item/I = O var/amount = get_amount(I) if(!amount) @@ -54,4 +49,16 @@ if(k_elasticity != 0) return round((prices_by_material[material_id]/k_elasticity) * (1 - NUM_E**(-1 * k_elasticity * amount))) else - return round(cost * amount) + return round(prices_by_material[material_id] * amount) + +/datum/export/material/market/sell_object(obj/sold_item, datum/export_report/report, dry_run, apply_elastic) + . = ..() + var/value = get_cost(sold_item, apply_elastic) + var/amount = get_amount(sold_item) + if(amount <= 0 || (value <= 0 && !allow_negative_cost)) + return FALSE + if(!dry_run) + if(apply_elastic) + prices_by_material[material_id] *= NUM_E**(-1 * k_elasticity * amount) + SSblackbox.record_feedback("nested tally", "export_sold_cost", 1, list("[sold_item.type]", "[value]")) + return TRUE