diff --git a/modular_skyrat/modules/ashwalkers/code/buildings/ash_farming.dm b/modular_skyrat/modules/ashwalkers/code/buildings/ash_farming.dm
index c1fcae5f962..f7979dee7c7 100644
--- a/modular_skyrat/modules/ashwalkers/code/buildings/ash_farming.dm
+++ b/modular_skyrat/modules/ashwalkers/code/buildings/ash_farming.dm
@@ -1,6 +1,4 @@
/datum/component/simple_farm
- ///whether you can actually farm it at the moment
- var/allow_plant = FALSE
///whether we limit the amount of plants you can have per turf
var/one_per_turf = TRUE
///the reference to the movable parent the component is attached to
@@ -14,7 +12,6 @@
return COMPONENT_INCOMPATIBLE
atom_parent = parent
//important to allow people to just straight up set allowing to plant
- allow_plant = set_plant
one_per_turf = set_turf_limit
pixel_shift = set_shift
//now lets register the signals
@@ -32,11 +29,6 @@
*/
/datum/component/simple_farm/proc/check_attack(datum/source, obj/item/attacking_item, mob/user)
SIGNAL_HANDLER
- //if it behaves like a shovel
- if(attacking_item.tool_behaviour == TOOL_SHOVEL)
- //flip the allow plant-- we either cover or uncover the plantable bit
- allow_plant = !allow_plant
- atom_parent.balloon_alert_to_viewers("[allow_plant ? "uncovered" : "covered"] the growing place!")
//if its a seed, lets try to plant
if(istype(attacking_item, /obj/item/seeds))
@@ -61,11 +53,7 @@
* check_examine is meant to listen for the COMSIG_ATOM_EXAMINE signal, where it will put additional information in the examine
*/
/datum/component/simple_farm/proc/check_examine(datum/source, mob/user, list/examine_list)
- if(allow_plant)
- examine_list += span_notice("You are able to plant seeds here!")
-
- else
- examine_list += span_warning("You need to use a shovel before you can plant seeds here!")
+ examine_list += span_notice("You are able to plant seeds here!")
/obj/structure/simple_farm
name = "simple farm"
@@ -108,9 +96,10 @@
/obj/structure/simple_farm/examine(mob/user)
. = ..()
. += span_notice("
[src] will be ready for harvest in [DisplayTimeText(COOLDOWN_TIMELEFT(src, harvest_timer))]")
- . += span_notice("
You can use sinew to lower the time between each harvest!")
- . += span_notice("You can use goliath hides to increase the amount dropped per harvest!")
- . += span_notice("You can use a regenerative core or worm fertilizer to force the plant to drop a harvest!")
+ if(max_harvest < 6)
+ . += span_notice("
You can use sinew or worm fertilizer to lower the time between each harvest!")
+ if(harvest_cooldown > 30 SECONDS)
+ . += span_notice("You can use goliath hides or worm fertilizer to increase the amount dropped per harvest!")
/obj/structure/simple_farm/process(seconds_per_tick)
update_appearance()
@@ -156,42 +145,71 @@
//if its sinew, lower the cooldown
else if(istype(attacking_item, /obj/item/stack/sheet/sinew))
- if(harvest_cooldown <= 30 SECONDS)
- balloon_alert(user, "the plant already grows fast!")
- return
-
var/obj/item/stack/sheet/sinew/use_item = attacking_item
if(!use_item.use(1))
return
- harvest_cooldown -= 15 SECONDS
- balloon_alert_to_viewers("the plant grows faster!")
+ decrease_cooldown(user)
return
//if its goliath hide, increase the amount dropped
else if(istype(attacking_item, /obj/item/stack/sheet/animalhide/goliath_hide))
- if(max_harvest >= 6)
- balloon_alert(user, "the plant already drops a lot!")
- return
-
var/obj/item/stack/sheet/animalhide/goliath_hide/use_item = attacking_item
if(!use_item.use(1))
return
- max_harvest++
- balloon_alert_to_viewers("the plant drops more!")
+ increase_yield(user)
return
- //if its a regen core or worm fertilizer, then create four harvests
- else if(istype(attacking_item, /obj/item/organ/internal/monster_core/regenerative_core) || istype(attacking_item, /obj/item/worm_fertilizer))
+ else if(istype(attacking_item, /obj/item/worm_fertilizer))
qdel(attacking_item)
- create_harvest()
+
+ if(!decrease_cooldown(user, silent = TRUE) && !increase_yield(user, silent = TRUE))
+ balloon_alert(user, "plant is already fully upgraded")
+
+ else
+ balloon_alert(user, "plant was upgraded")
+
return
return ..()
+/**
+ * a proc that will increase the amount of items the crop could produce (at a maximum of 6, from base of 3)
+ */
+/obj/structure/simple_farm/proc/increase_yield(mob/user, var/silent = FALSE)
+ if(max_harvest >= 6)
+ if(!silent)
+ balloon_alert(user, "plant is at maximum yield")
+
+ return FALSE
+
+ max_harvest++
+
+ if(!silent)
+ balloon_alert_to_viewers("plant will have increased yield")
+
+ return TRUE
+
+/**
+ * a proc that will decrease the amount of time it takes to be ready for harvest (at a maximum of 30 seconds, from a base of 1 minute)
+ */
+/obj/structure/simple_farm/proc/decrease_cooldown(mob/user, var/silent = FALSE)
+ if(harvest_cooldown <= 30 SECONDS)
+ if(!silent)
+ balloon_alert(user, "already at maximum growth speed!")
+
+ return FALSE
+
+ harvest_cooldown -= 10 SECONDS
+
+ if(!silent)
+ balloon_alert_to_viewers("plant will grow faster")
+
+ return TRUE
+
/**
* used during the component so that it can move when its attached atom moves
*/
diff --git a/modular_skyrat/modules/ashwalkers/code/buildings/wormfarm.dm b/modular_skyrat/modules/ashwalkers/code/buildings/wormfarm.dm
index 5d7a69d5a77..c47ad6ef9eb 100644
--- a/modular_skyrat/modules/ashwalkers/code/buildings/wormfarm.dm
+++ b/modular_skyrat/modules/ashwalkers/code/buildings/wormfarm.dm
@@ -9,6 +9,8 @@
var/max_worm = 10
/// How many worms the barrel is currently holding
var/current_worm = 0
+ /// How much food was inserted into the barrel that needs to be composted
+ var/current_food = 0
/// If the barrel is currently being used by someone
var/in_use = FALSE
// The cooldown between each worm "breeding"
@@ -30,10 +32,12 @@
COOLDOWN_START(src, worm_timer, 1 MINUTES)
- if(current_worm < 2 || current_worm >= max_worm)
- return
+ if(current_worm > 2 && current_worm < max_worm)
+ current_worm++
- current_worm++
+ if(current_food > 0 && current_worm > 1)
+ current_food--
+ new /obj/item/worm_fertilizer(get_turf(src))
/obj/structure/wormfarm/examine(mob/user)
. = ..()
@@ -49,7 +53,7 @@
return ..()
balloon_alert(user, "digging up worms")
- if(!do_after(user, 5 SECONDS, src))
+ if(!do_after(user, 2 SECONDS, src))
balloon_alert(user, "stopped digging")
in_use = FALSE
return ..()
@@ -96,10 +100,9 @@
return
qdel(attacking_item)
- balloon_alert(user, "feeding complete")
+ balloon_alert(user, "feeding complete, check back later")
- if(current_worm > 0)
- new /obj/item/worm_fertilizer(get_turf(src))
+ current_food++
in_use = FALSE
return