diff --git a/_maps/map_files/RandomRuins/LavaRuins/lavaland_surface_ash_walker1.dmm b/_maps/map_files/RandomRuins/LavaRuins/lavaland_surface_ash_walker1.dmm index 85a6f8c9e40..8872db92fa5 100644 --- a/_maps/map_files/RandomRuins/LavaRuins/lavaland_surface_ash_walker1.dmm +++ b/_maps/map_files/RandomRuins/LavaRuins/lavaland_surface_ash_walker1.dmm @@ -244,6 +244,7 @@ /turf/simulated/floor/lava, /area/ruin/unpowered/ash_walkers) "aK" = ( +/mob/living/simple_animal/hostile/asteroid/gutlunch/gubbuck, /obj/structure/stone_tile/block/cracked{ dir = 8 }, @@ -251,7 +252,6 @@ dir = 1 }, /obj/structure/stone_tile, -/mob/living/simple_animal/hostile/asteroid/gutlunch/gubbuck, /turf/simulated/floor/indestructible/boss/indoors, /area/ruin/unpowered/ash_walkers) "aM" = ( @@ -277,6 +277,7 @@ /area/ruin/unpowered/ash_walkers) "aP" = ( /obj/structure/stone_tile, +/obj/item/healthanalyzer/gem_analyzer, /turf/simulated/floor/plating/asteroid/basalt/lava_land_surface, /area/ruin/unpowered/ash_walkers) "aQ" = ( @@ -372,6 +373,7 @@ /turf/simulated/floor/plating/asteroid/basalt/lava_land_surface, /area/ruin/unpowered/ash_walkers) "bc" = ( +/mob/living/simple_animal/hostile/asteroid/gutlunch/guthen, /obj/structure/stone_tile/block{ dir = 4 }, @@ -381,7 +383,6 @@ /obj/structure/stone_tile{ dir = 4 }, -/mob/living/simple_animal/hostile/asteroid/gutlunch/guthen, /turf/simulated/floor/indestructible/boss/indoors, /area/ruin/unpowered/ash_walkers) "bd" = ( @@ -485,7 +486,7 @@ /obj/structure/stone_tile/cracked{ dir = 4 }, -/obj/item/rcd/preloaded, +/obj/item/stack/fireproof_rods/twentyfive, /turf/simulated/floor/indestructible/boss, /area/ruin/unpowered/ash_walkers) "bn" = ( @@ -1402,6 +1403,14 @@ }, /turf/simulated/mineral/volcanic/lava_land_surface, /area/lavaland/surface/outdoors) +"jq" = ( +/obj/structure/stone_tile{ + dir = 1 + }, +/obj/effect/mapping_helpers/no_lava, +/obj/machinery/smartfridge/drying_rack/ash, +/turf/simulated/floor/plating/asteroid/basalt/lava_land_surface, +/area/lavaland/surface/outdoors) "qj" = ( /obj/structure/stone_tile/cracked{ dir = 4 @@ -1590,7 +1599,7 @@ ba bn bz ak -cb +jq df bX co diff --git a/code/datums/mapgen/LavalandGenerator.dm b/code/datums/mapgen/LavalandGenerator.dm index fec2ecf9b57..e8828241907 100644 --- a/code/datums/mapgen/LavalandGenerator.dm +++ b/code/datums/mapgen/LavalandGenerator.dm @@ -26,7 +26,8 @@ /obj/structure/flora/ash/stem_shroom = 2, /obj/structure/flora/ash/cacti = 1, /obj/structure/flora/ash/tall_shroom = 2, - /obj/structure/flora/ash/fireblossom = 2 + /obj/structure/flora/ash/fireblossom = 2, + /obj/structure/flora/ash/coaltree = 1 ) smoothing_iterations = 50 diff --git a/code/game/objects/items/devices/scanners.dm b/code/game/objects/items/devices/scanners.dm index d3620082bb2..d0174fddcc4 100644 --- a/code/game/objects/items/devices/scanners.dm +++ b/code/game/objects/items/devices/scanners.dm @@ -713,6 +713,17 @@ REAGENT SCANNER origin_tech = "magnets=2;biotech=2" usesound = 'sound/items/deconstruct.ogg' +/obj/item/healthanalyzer/gem_analyzer + name = "eye of health" + icon = 'icons/obj/device.dmi' + icon_state = "Gem_analyzer" + item_state = "gem_analyzer" + desc = "Необычный самоцвет в форме сердца." + origin_tech = null + +/obj/item/healthanalyzer/gem_analyzer/attackby(obj/item/I, mob/user, params) + return ATTACK_CHAIN_BLOCKED_ALL + /obj/item/reagent_scanner name = "reagent scanner" desc = "A hand-held reagent scanner which identifies chemical agents and blood types." diff --git a/code/game/objects/items/stacks/sheets/leather.dm b/code/game/objects/items/stacks/sheets/leather.dm index 36d211ea34b..790f833a94c 100644 --- a/code/game/objects/items/stacks/sheets/leather.dm +++ b/code/game/objects/items/stacks/sheets/leather.dm @@ -286,7 +286,7 @@ GLOBAL_LIST_INIT(sinew_recipes, list ( \ if(!do_after(user, 5 SECONDS * I.toolspeed, src, category = DA_CAT_TOOL)) return ATTACK_CHAIN_PROCEED to_chat(user, span_notice("You cut the hair from [src].")) - var/obj/item/stack/sheet/hairlesshide/hide = new(drop_location(), amount) + var/obj/item/stack/sheet/hairlesshide/hide = new(drop_location(), 3 * amount) hide.add_fingerprint(user) qdel(src) return ATTACK_CHAIN_BLOCKED_ALL diff --git a/code/game/objects/items/tent.dm b/code/game/objects/items/tent.dm new file mode 100644 index 00000000000..b5bf7342363 --- /dev/null +++ b/code/game/objects/items/tent.dm @@ -0,0 +1,200 @@ +/obj/item/folded_tent + name = "primitive folded tent" + desc = "Сложенная палатка." + icon = 'icons/obj/tent.dmi' + icon_state = "tent_folded" + item_state = "tent_folded" + w_class = WEIGHT_CLASS_BULKY + slot_flags = ITEM_SLOT_BACK + var/unfoldedtent_path = /obj/structure/tent + +/obj/item/folded_tent/attack_self(mob/user) + if(!do_after(user, 15 SECONDS, user)) + return + if(loc == user) + deploy_tent(user, get_turf(user)) + else + deploy_tent(user, get_turf(src)) + +/obj/item/folded_tent/pickup(mob/user) + if(contains(user)) + return FALSE + return ..() + +/obj/item/folded_tent/proc/deploy_tent(mob/user, atom/location) + var/obj/structure/tent/item_tent = new unfoldedtent_path(location) + item_tent.foldedtent_instance = src + user.drop_item_ground(src) + move_to_null_space() + return item_tent + +/obj/structure/tent + name = "Primitive tent" + desc = "Примитивная палатка, способная защитить от бури. Сделана из шкур голиафов." + icon = 'icons/obj/tent.dmi' + icon_state = "tent" + max_integrity = 50 + density = TRUE + anchored = TRUE + var/foldedtent_path = /obj/item/folded_tent + var/obj/item/folded_tent/foldedtent_instance = null + var/mob/living/carbon/human/occupant = null + +/obj/structure/tent/proc/perform_fold(mob/living/carbon/human/the_folder) + var/folding_tent = new foldedtent_path(get_turf(src)) + the_folder.put_in_hands(folding_tent) + +/obj/structure/tent/MouseDrop(atom/over_object, src_location, over_location, src_control, over_control, params) + if(!do_after(usr, 5 SECONDS, usr)) + return + + if(over_object == usr && ishuman(usr) && !usr.incapacitated() && !HAS_TRAIT(usr, TRAIT_HANDS_BLOCKED) && !length(contents) && usr.Adjacent(src)) + usr.visible_message( + span_notice("[usr] folds up [src]."), + span_notice("You fold up [src]."), + ) + perform_fold(usr) + qdel(src) + return FALSE + + if(over_object == usr && ishuman(usr) && !usr.incapacitated() && usr.Adjacent(src)) + if(attempt_fold(usr)) + usr.visible_message( + span_notice("[usr] folds up [src]."), + span_notice("You fold up [src]."), + ) + perform_fold(usr) + qdel(src) + return FALSE + + return ..() + +/obj/structure/tent/proc/attempt_fold(mob/living/carbon/human/the_folder) + . = FALSE + if(!istype(the_folder)) + return + + if(LAZYLEN(contents)) + return + + return TRUE + +/obj/structure/tent/grab_attack(mob/living/grabber, atom/movable/grabbed_thing) + . = TRUE + if(grabber.grab_state < GRAB_AGGRESSIVE || !ismob(grabbed_thing)) + return . + + var/mob/target = grabbed_thing + if(occupant) + grabber.balloon_alert(grabber, "палатка занята!") + return . + + visible_message(span_notice("[grabber] starts putting [target] into [src].")) + if(!do_after(grabber, 2 SECONDS, target) || !target || !grabber || grabber.pulling != target || !grabber.Adjacent(src)) + return . + + target.forceMove(src) + occupant = target + +/obj/structure/tent/MouseDrop_T(atom/movable/O, mob/user, params) + if(O.loc == user) + return + + if(user.incapacitated() || HAS_TRAIT(user, TRAIT_HANDS_BLOCKED)) + return + + if(get_dist(user, src) > 1 || get_dist(user, O) > 1 || user.contents.Find(src)) + return + + if(!ismob(O)) + return + + if(isanimal(O) || issilicon(O)) + return + + if(!isturf(user.loc) || !isturf(O.loc)) + return + + if(occupant) + usr.balloon_alert(usr, "палатка занята!") + return TRUE + + var/mob/living/L = O + if(!istype(L) || L.buckled) + return + + if(L == user) + visible_message(span_notice("[user] starts climbing into the tent.")) + else + visible_message(span_notice("[user] starts putting [L.name] into the tent.")) + + . = TRUE + INVOKE_ASYNC(src, PROC_REF(put_in), L, user) + +/obj/structure/tent/Destroy() + for(var/mob/M in contents) + M.forceMove(get_turf(src)) + REMOVE_TRAIT(M, TRAIT_ASHSTORM_IMMUNE, "ash") + + return ..() + +/obj/structure/tent/proc/put_in(mob/living/L, mob/user) + if(!do_after(user, 2 SECONDS, L)) + return + + if(occupant) + user.balloon_alert(user, "палатка занята!") + return + + if(!L) + return + + L.forceMove(src) + occupant = L + ADD_TRAIT(L, TRAIT_ASHSTORM_IMMUNE, "ash") + +/obj/structure/tent/verb/move_inside() + set name = "Enter Tent" + set category = "Object" + set src in oview(1) + if(!ishuman(usr) || usr.incapacitated() || HAS_TRAIT(usr, TRAIT_HANDS_BLOCKED) || usr.buckled) + return + + if(occupant) + usr.balloon_alert(usr, "палатка занята!") + return + + visible_message(span_notice("[usr] starts climbing into the tent.")) + put_in(usr, usr) + +/obj/structure/tent/verb/eject() + set name = "Eject Tent" + set category = "Object" + set src in oview(1) + + if(usr.default_can_use_topic(src) != UI_INTERACTIVE) + return + + if(usr.incapacitated() || HAS_TRAIT(usr, TRAIT_HANDS_BLOCKED)) + return + + go_out() + add_fingerprint(usr) + +/obj/structure/tent/relaymove(mob/user as mob) + go_out() + +/obj/structure/tent/proc/go_out() + if(!occupant) + return + + occupant.forceMove(loc) + if(!istype(occupant, /datum/species/unathi/draconid)) + REMOVE_TRAIT(occupant, TRAIT_ASHSTORM_IMMUNE, "ash") + occupant = null + +/obj/structure/tent/force_eject_occupant(mob/target) + go_out() + +/obj/structure/tent/attack_ai(mob/user) + return attack_hand(user) diff --git a/code/game/objects/items/weapons/shields.dm b/code/game/objects/items/weapons/shields.dm index 9451a19cd47..50fbc1ddb6c 100644 --- a/code/game/objects/items/weapons/shields.dm +++ b/code/game/objects/items/weapons/shields.dm @@ -89,7 +89,7 @@ item_state = "goliath_shield" materials = list() origin_tech = "materials=1;combat=3;biotech=2" - block_chance = 30 + block_chance = 45 obj_integrity = 380 max_integrity = 380 diff --git a/code/game/objects/items/weapons/weaponry.dm b/code/game/objects/items/weapons/weaponry.dm index 2d9b7ef9f96..d67c45a9f79 100644 --- a/code/game/objects/items/weapons/weaponry.dm +++ b/code/game/objects/items/weapons/weaponry.dm @@ -450,3 +450,29 @@ w_class = WEIGHT_CLASS_BULKY block_chance = 30 +/obj/item/kolotushka + name = "primitive kolotushka" + desc = "Простейшая дубина из кости, воплощает в себе силу природы и первобытную мощь." + icon_state = "kolotushka" + item_state = "kolotushka" + hitsound = 'sound/weapons/kolotushka_smash.ogg' + slot_flags = ITEM_SLOT_BELT + force = 3 + throwforce = 3 + w_class = WEIGHT_CLASS_NORMAL + var/stamina_damage = 22 + +/obj/item/kolotushka/afterattack(atom/target, mob/user, proximity, params, status) + if(!isliving(target) || !proximity || user.incapacitated() || HAS_TRAIT(user, TRAIT_HANDS_BLOCKED)) + return + + var/mob/living/victim = target + if(isrobot(victim)) + if(prob(30)) + victim.flash_eyes(3 SECONDS) + victim.Stun(3 SECONDS) + + if(ishuman(victim)) + victim.apply_damage(stamina_damage, STAMINA, blocked = victim.getarmor(user.zone_selected, MELEE)) + if(prob(30)) + victim.Knockdown(3 SECONDS) diff --git a/code/game/objects/structures/watercloset.dm b/code/game/objects/structures/watercloset.dm index fd275dccef0..20461905d0c 100644 --- a/code/game/objects/structures/watercloset.dm +++ b/code/game/objects/structures/watercloset.dm @@ -702,6 +702,14 @@ can_rotate = 0 resistance_flags = UNACIDABLE +/obj/structure/sink/puddle/Initialize(mapload) + . = ..() + + var/static/list/loc_connections = list( + COMSIG_ATOM_ENTERED = PROC_REF(on_entered), + ) + AddElement(/datum/element/connect_loc, loc_connections) + /obj/structure/sink/puddle/attack_hand(mob/user) flick("puddle-splash", src) @@ -731,6 +739,22 @@ return ..() +/obj/structure/sink/puddle/proc/on_entered(datum/source, atom/movable/arrived, atom/old_loc, list/atom/old_locs) + SIGNAL_HANDLER + wash(arrived) + +/obj/structure/sink/puddle/proc/wash(atom/target) + if(isitem(target)) + var/obj/item/item = target + item.extinguish() + + if(isliving(target)) + var/mob/living/l_target = target + l_target.ExtinguishMob() + l_target.adjust_fire_stacks(-20) + to_chat(l_target, span_warning("You've been drenched in water!")) + + target.clean_blood() ////////////////////////////////// // Bathroom Fixture Items // diff --git a/code/modules/clothing/gloves/miscellaneous.dm b/code/modules/clothing/gloves/miscellaneous.dm index ac3749345c2..4b33fb8c584 100644 --- a/code/modules/clothing/gloves/miscellaneous.dm +++ b/code/modules/clothing/gloves/miscellaneous.dm @@ -18,7 +18,36 @@ desc = "Grey gloves without fingertips made from the hide of a dead arachnid found on lavaland. Makes wearer stronger in disarming ability." icon_state = "weaver_chitin" item_state = "weaver_chitin" - extra_knock_chance = 5 + extra_knock_chance = 20 + var/stamdamage_low = 10 + var/stamdamage_high = 15 + +/obj/item/clothing/gloves/fingerless/weaver/Touch(atom/A, proximity) + . = FALSE + if(!ishuman(loc)) + return FALSE + + var/mob/living/carbon/human/user = loc + if(!user.mind || user.mind.martial_art) + return FALSE + + if(user.a_intent != INTENT_HARM || !proximity || isturf(A)) + return FALSE + + var/damage = rand(user.dna.species.punchdamagelow + user.physiology.punch_damage_low, user.dna.species.punchdamagehigh + user.physiology.punch_damage_high) + var/stamindamage = rand(stamdamage_low, stamdamage_high) + if(ishuman(A)) + user.do_attack_animation(A, "kick") + playsound(get_turf(user), 'sound/effects/hit_punch.ogg', 50, 1, -1) + var/mob/living/carbon/human/target = A + var/obj/item/organ/external/affecting = target.get_organ(ran_zone(user.zone_selected)) + add_attack_logs(user, target, "Melee attacked with weaver gloves") + + target.visible_message(span_danger("[user] smash [target] with weaver gloves!")) + + target.apply_damage(damage, BRUTE, affecting) + target.apply_damage(stamindamage, STAMINA, affecting) + return TRUE /obj/item/clothing/gloves/cyborg desc = "beep boop borp" diff --git a/code/modules/clothing/suits/armor.dm b/code/modules/clothing/suits/armor.dm index 32abf1fb95c..85ba6092d50 100644 --- a/code/modules/clothing/suits/armor.dm +++ b/code/modules/clothing/suits/armor.dm @@ -639,7 +639,7 @@ item_state = "goliath_cloak" desc = "A staunch, practical cape made out of numerous monster materials, it is coveted amongst exiles & hermits." allowed = list(/obj/item/flashlight, /obj/item/tank/internals, /obj/item/pickaxe, /obj/item/twohanded/spear, /obj/item/organ/internal/regenerative_core/legion, /obj/item/kitchen/knife/combat/survival, /obj/item/twohanded/kinetic_crusher, /obj/item/hierophant_club, /obj/item/twohanded/fireaxe/boneaxe) - armor = list("melee" = 40, "bullet" = 15, "laser" = 30, "energy" = 15, "bomb" = 35, "bio" = 0, "rad" = 0, "fire" = 60, "acid" = 60) //a fair alternative to bone armor, requiring alternative materials and gaining a suit slot + armor = list("melee" = 40, "bullet" = 15, "laser" = 30, "energy" = 15, "bomb" = 35, "bio" = 0, "rad" = 0, "fire" = 80, "acid" = 60) //a fair alternative to bone armor, requiring alternative materials and gaining a suit slot hoodtype = /obj/item/clothing/head/hooded/goliath body_parts_covered = UPPER_TORSO|LOWER_TORSO|ARMS @@ -648,7 +648,7 @@ icon_state = "golhood" item_state = "golhood" desc = "A protective & concealing hood." - armor = list("melee" = 40, "bullet" = 15, "laser" = 30, "energy" = 15, "bomb" = 35, "bio" = 0, "rad" = 0, "fire" = 60, "acid" = 60) + armor = list("melee" = 40, "bullet" = 15, "laser" = 30, "energy" = 15, "bomb" = 35, "bio" = 0, "rad" = 0, "fire" = 80, "acid" = 60) flags_inv = HIDEHAIR flags_cover = HEADCOVERSEYES diff --git a/code/modules/crafting/recipes.dm b/code/modules/crafting/recipes.dm index 4dcd10981ba..92fc4cc364f 100644 --- a/code/modules/crafting/recipes.dm +++ b/code/modules/crafting/recipes.dm @@ -675,6 +675,21 @@ result = /obj/item/stack/medical/splint/tribal category = CAT_PRIMAL +/datum/crafting_recipe/primitive_surgical_kit + name = "Primitive surgical kit" + time = 30 + reqs = list(/obj/item/stack/sheet/bone = 6, + /obj/item/stack/sheet/sinew = 3) + result = list(/obj/item/retractor/primitive_retractor, + /obj/item/hemostat/primitive_hemostat, + /obj/item/cautery/primitive_cautery, + /obj/item/scalpel/primitive_scalpel, + /obj/item/primitive_saw, + /obj/item/bonegel/primitive_bonegel, + /obj/item/FixOVein/primitive_FixOVein, + /obj/item/bonesetter/primitive_bonesetter) + category = CAT_PRIMAL + /datum/crafting_recipe/bonedagger name = "Bone Dagger" result = /obj/item/kitchen/knife/combat/survival/bone @@ -695,7 +710,7 @@ result = /obj/item/shield/riot/goliath time = 6 SECONDS reqs = list(/obj/item/stack/sheet/bone = 4, - /obj/item/stack/sheet/animalhide/goliath_hide = 3) + /obj/item/stack/sheet/animalhide/goliath_hide = 2) category = CAT_PRIMAL /datum/crafting_recipe/bonespear @@ -798,6 +813,10 @@ category = CAT_PRIMAL alert_admins_on_craft = TRUE +/datum/crafting_recipe/bonfire/coaltree + name = "Bonfire (coaltree)" + reqs = list(/obj/item/reagent_containers/food/snacks/grown/ash_flora/coaltree_log = 5) + /datum/crafting_recipe/rake //Category resorting incoming name = "Rake" time = 30 @@ -1477,9 +1496,9 @@ time = 5 SECONDS reqs = list(/obj/item/clothing/suit/hooded/goliath = 1, /obj/item/stack/sheet/animalhide/goliath_hide = 2, //2 plates for the cloak plus 2 here plus 3 for plating the armor = 7 total - /obj/item/stack/sheet/animalhide/weaver_chitin = 10, - /obj/item/stack/sheet/bone = 8, - /obj/item/stack/sheet/sinew = 10) + /obj/item/stack/sheet/animalhide/weaver_chitin = 6, + /obj/item/stack/sheet/bone = 5, + /obj/item/stack/sheet/sinew = 5) category = CAT_PRIMAL /datum/crafting_recipe/pathtreads @@ -1551,7 +1570,7 @@ /obj/item/stack/sheet/mineral/diamond = 5 ) result = list(/obj/item/pickaxe/diamond) - + /datum/crafting_recipe/drone name = "Inactive Drone" result = list(/obj/item/inactive_drone) @@ -1611,3 +1630,28 @@ category = CAT_ROBOT always_availible = FALSE time = 1 SECONDS + +/datum/crafting_recipe/ashrack + name = "Primitive drying rack" + result = /obj/machinery/smartfridge/drying_rack/ash + time = 15 SECONDS + reqs = list(/obj/item/stack/sheet/wood = 2, + /obj/item/stack/sheet/sinew = 1) + category = CAT_PRIMAL + +/datum/crafting_recipe/tent + name = "Primitive tent" + result = /obj/item/folded_tent + time = 15 SECONDS + reqs = list(/obj/item/stack/sheet/bone = 2, + /obj/item/stack/sheet/animalhide/goliath_hide = 2, + /obj/item/stack/sheet/sinew = 1) + category = CAT_PRIMAL + +/datum/crafting_recipe/kolotushka + name = "Primitive kolotushka" + result = /obj/item/kolotushka + time = 4 SECONDS + reqs = list(/obj/item/stack/sheet/bone = 2, + /obj/item/stack/sheet/animalhide/weaver_chitin = 2) + category = CAT_PRIMAL diff --git a/code/modules/food_and_drinks/food/foods/meat.dm b/code/modules/food_and_drinks/food/foods/meat.dm index 1d40095fe2e..306e0738fc9 100644 --- a/code/modules/food_and_drinks/food/foods/meat.dm +++ b/code/modules/food_and_drinks/food/foods/meat.dm @@ -57,6 +57,21 @@ cutlet.add_fingerprint(user) qdel(src) +/obj/item/reagent_containers/food/snacks/meat/burn() + visible_message(span_notice("[src] finishes cooking!")) + new /obj/item/reagent_containers/food/snacks/roasted_meat(loc) + qdel(src) + +/obj/item/reagent_containers/food/snacks/roasted_meat + name = "roasted meat" + desc = "Хорошо прожаренный стейк." + resistance_flags = LAVA_PROOF | FIRE_PROOF + icon_state = "roasted_meat" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + list_reagents = list("protein" = 4, "vitamin" = 1) + tastes = list("meat" = 1) + foodtype = MEAT /obj/item/reagent_containers/food/snacks/meat/syntiflesh name = "synthetic meat" @@ -420,6 +435,11 @@ list_reagents = list("protein" = 2, "toxin" = 2) tastes = list("cobwebs" = 1, "creepy motion" = 1) +/obj/item/reagent_containers/food/snacks/monstermeat/spiderleg/burn() + visible_message(span_notice("[src] finishes cooking!")) + new /obj/item/reagent_containers/food/snacks/roasted_spiderleg(loc) + qdel(src) + /obj/item/reagent_containers/food/snacks/raw_bacon name = "raw bacon" desc = "God's gift to man in uncooked form." @@ -443,7 +463,7 @@ tastes = list("tough meat" = 1) /obj/item/reagent_containers/food/snacks/monstermeat/goliath/burn() - visible_message("[src] finishes cooking!") + visible_message(span_notice("[src] finishes cooking!")) new /obj/item/reagent_containers/food/snacks/goliath_steak(loc) qdel(src) @@ -456,7 +476,7 @@ tastes = list("meat" = 1) /obj/item/reagent_containers/food/snacks/monstermeat/goldgrub/burn() - visible_message("[src] finishes cooking!") + visible_message(span_notice("[src] finishes cooking!")) new /obj/item/reagent_containers/food/snacks/goldgrubmeat(loc) qdel(src) @@ -700,6 +720,17 @@ tastes = list("meat" = 1) foodtype = MEAT +/obj/item/reagent_containers/food/snacks/roasted_spiderleg + name = "roasted spider leg" + desc = "Жаренная лапка паука, теперь оно точно мертво." + resistance_flags = LAVA_PROOF | FIRE_PROOF + icon_state = "roasted_spiderleg" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + list_reagents = list("protein" = 4, "vitamin" = 1) + tastes = list("cobwebs" = 1, "meat" = 1) + foodtype = MEAT + /obj/item/reagent_containers/food/snacks/goldgrubmeat name= "goldgrub steak" desc = "Cooked intestines with goldgrub skin, retrieved from a Goldgrub. Legends say it is valuable in traditional medicines." diff --git a/code/modules/food_and_drinks/kitchen_machinery/smartfridge.dm b/code/modules/food_and_drinks/kitchen_machinery/smartfridge.dm index b9efa4e202a..216456986c4 100644 --- a/code/modules/food_and_drinks/kitchen_machinery/smartfridge.dm +++ b/code/modules/food_and_drinks/kitchen_machinery/smartfridge.dm @@ -789,6 +789,8 @@ active_power_usage = 200 can_dry = TRUE visible_contents = FALSE + var/primitive = FALSE //used for energy consuming stuff + var/drying_timer = 1 icon_lightmask = null /obj/machinery/smartfridge/drying_rack/Initialize(mapload) @@ -810,6 +812,9 @@ return /obj/machinery/smartfridge/drying_rack/power_change(forced = FALSE) + if(primitive) + return + if(powered() && anchored) stat &= ~NOPOWER else @@ -839,10 +844,10 @@ switch(action) if("drying") drying = !drying - use_power = drying ? ACTIVE_POWER_USE : IDLE_POWER_USE + if(!primitive) + use_power = drying ? ACTIVE_POWER_USE : IDLE_POWER_USE update_icon(UPDATE_OVERLAYS) - /obj/machinery/smartfridge/drying_rack/update_overlays() . = list() if(drying) @@ -852,9 +857,14 @@ /obj/machinery/smartfridge/drying_rack/process() - if(drying && rack_dry())//no need to update unless something got dried - update_icon(UPDATE_OVERLAYS) - + ..() + if(drying)//no need to update unless something got dried + if(drying_timer && length(contents)) + drying_timer-- + else + rack_dry() + drying_timer = initial(drying_timer) + update_icon(UPDATE_OVERLAYS) /obj/machinery/smartfridge/drying_rack/accept_check(obj/item/O) . = ..() @@ -903,3 +913,25 @@ SStgui.update_uis(src) return TRUE return FALSE + +/obj/machinery/smartfridge/drying_rack/ash + name = "primitive drying rack" + desc = "Самодельная сушилка, используется для сушки кожи и еды." + icon_state = "primitive-drying-rack" + use_power = NO_POWER_USE + can_dry = FALSE //trust me + drying = TRUE + idle_power_usage = 0 + active_power_usage = 0 + drying_timer = 8 + primitive = TRUE + +/obj/machinery/smartfridge/drying_rack/ash/update_overlays() + overlays.Cut() + if(length(contents)) + overlays += "primitive-drying-rack_leather" + +/obj/machinery/smartfridge/drying_rack/ash/on_deconstruction() + new /obj/item/stack/sheet/wood(loc, 2) + new /obj/item/stack/sheet/sinew(loc, 1) + ..() diff --git a/code/modules/mining/lavaland/ash_flora.dm b/code/modules/mining/lavaland/ash_flora.dm index ec3ba9b9d1c..8e275d62d2a 100644 --- a/code/modules/mining/lavaland/ash_flora.dm +++ b/code/modules/mining/lavaland/ash_flora.dm @@ -178,6 +178,21 @@ regrowth_time_low = 2500 regrowth_time_high = 4000 +/obj/structure/flora/ash/coaltree + icon_state = "coaltree" + name = "coaltree" + desc = "Небольшое мрачное дерево, растущее на просторах такой же мрачной планеты." + harvested_name = "coaltree stump" + harvested_desc = "Голый ствол дерева, оставшийся без своей уродливой кроны." + harvest = /obj/item/reagent_containers/food/snacks/grown/ash_flora/coaltree_log + harvest_amount_high = 5 + harvest_time = 40 + harvest_message_low = "Вы обрезаете небольшое дерево." + harvest_message_med = "Вы обрезаете дерево среднего размера." + harvest_message_high = "Вы обрезаете большое дерево." + regrowth_time_low = 4000 + regrowth_time_high = 6000 + /obj/item/reagent_containers/food/snacks/grown/ash_flora name = "mushroom shavings" desc = "Some shavings from a tall mushroom. With enough, might serve as a bowl." @@ -232,6 +247,35 @@ seed = /obj/item/seeds/lavaland/fireblossom wine_power = 0.4 +/obj/item/reagent_containers/food/snacks/grown/ash_flora/coaltree_log + name = "coaltree log" + desc = "Бревно угледрева, на ощупь мягкое." + icon_state = "coaltree_log" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + item_state = "coaltree_log" + seed = /obj/item/seeds/lavaland/coaltree + wine_power = 0.5 + item_flags = NOBLUDGEON + w_class = WEIGHT_CLASS_NORMAL + +/obj/item/reagent_containers/food/snacks/grown/ash_flora/coaltree_log/attackby(obj/item/I, mob/user, params) + if(is_sharp(I)) + if(!isturf(loc)) + add_fingerprint(user) + to_chat(user, span_warning("You cannot chop [src] [ismob(loc) ? "in inventory" : "in [loc]"].")) + return ATTACK_CHAIN_PROCEED + + to_chat(user, span_notice("You have chopped [src] into planks.")) + var/seed_modifier = 0 + if(seed) + seed_modifier = round(seed.potency / 25) + var/obj/item/stack/planks = new /obj/item/stack/sheet/wood(loc, 1 + seed_modifier) + transfer_fingerprints_to(planks) + planks.add_fingerprint(user) + qdel(src) + return ATTACK_CHAIN_BLOCKED_ALL + //SEEDS /obj/item/seeds/lavaland @@ -316,6 +360,18 @@ genes = list(/datum/plant_gene/trait/fire_resistance, /datum/plant_gene/trait/glow/yellow) reagents_add = list("tinlux" = 0.04, "nutriment" = 0.03, "carbon" = 0.05) +/obj/item/seeds/lavaland/coaltree + name = "pack of coaltree seeds" + desc = "These seeds grow into coaltree." + icon_state = "seed-coaltree" + species = "coaltree" + plantname = "Coaltree" + growthstages = 3 + growing_icon = 'icons/obj/hydroponics/growing.dmi' + product = /obj/item/reagent_containers/food/snacks/grown/ash_flora/coaltree_log + genes = list(/datum/plant_gene/trait/fire_resistance) + reagents_add = list("nutriment" = 0.04, "coaltree_extract" = 0.1) + //CRAFTING //what you can craft with these things diff --git a/code/modules/mob/living/simple_animal/hostile/mining/goliath.dm b/code/modules/mob/living/simple_animal/hostile/mining/goliath.dm index b9a6169ab4b..0fd7109c0b7 100644 --- a/code/modules/mob/living/simple_animal/hostile/mining/goliath.dm +++ b/code/modules/mob/living/simple_animal/hostile/mining/goliath.dm @@ -245,8 +245,7 @@ pre_attack_icon = "Goliath_preattack" throw_message = "does nothing to the rocky hide of the" crusher_loot = /obj/item/crusher_trophy/eyed_tentacle - loot = list(/obj/item/stack/sheet/animalhide/goliath_hide) //A throwback to the asteroid days - butcher_results = list(/obj/item/reagent_containers/food/snacks/monstermeat/goliath = 2, /obj/item/stack/sheet/bone = 2) + butcher_results = list(/obj/item/reagent_containers/food/snacks/monstermeat/goliath= 2, /obj/item/stack/sheet/animalhide/goliath_hide = 2, /obj/item/stack/sheet/bone = 2) crusher_drop_mod = 30 wander = FALSE var/list/cached_tentacle_turfs diff --git a/code/modules/projectiles/guns/projectile/bow.dm b/code/modules/projectiles/guns/projectile/bow.dm index 1a4211d78f3..d9105d1aeb9 100644 --- a/code/modules/projectiles/guns/projectile/bow.dm +++ b/code/modules/projectiles/guns/projectile/bow.dm @@ -111,6 +111,23 @@ range = 10 damage = 25 damage_type = BRUTE + var/faction_bonus_damage = 13 + var/nemesis_factions = list("mining", "boss") + var/nemesis_faction = FALSE + +/obj/item/projectile/bullet/reusable/arrow/prehit(atom/target) + var/mob/living/H = target + + if(!ismob(H) || !LAZYLEN(nemesis_factions)) + return + + for(var/faction in H.faction) + if(faction in nemesis_factions) + nemesis_faction = TRUE + damage += faction_bonus_damage + break + + . = ..() /obj/item/projectile/bullet/reusable/arrow/bone //A fully upgraded normal arrow; it's got the stats to show. Still *less* damage than a slug, slower, and with negative AP. Only for bone bow! name = "bone-tipped arrow" @@ -119,11 +136,15 @@ range = 12 damage = 45 armour_penetration = -10 + faction_bonus_damage = 23 /obj/item/ammo_casing/caseless/arrow name = "arrow" desc = "Stab, stab, stab." icon_state = "arrow" + item_state = "arrow" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' force = 10 projectile_type = /obj/item/projectile/bullet/reusable/arrow muzzle_flash_effect = null @@ -133,6 +154,9 @@ name = "bone-tipped arrow" desc = "An arrow made from bone, wood, and sinew. Sturdy and sharp." icon_state = "bone_arrow" + item_state = "bone_arrow" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' force = 12 projectile_type = /obj/item/projectile/bullet/reusable/arrow/bone caliber = "bone_arrow" diff --git a/code/modules/projectiles/guns/throw/crossbow.dm b/code/modules/projectiles/guns/throw/crossbow.dm index a1afbe1724c..41abf5cdf89 100644 --- a/code/modules/projectiles/guns/throw/crossbow.dm +++ b/code/modules/projectiles/guns/throw/crossbow.dm @@ -192,6 +192,8 @@ desc = "It's got a tip for you - get the point?" icon_state = "bolt" item_state = "bolt" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' throwforce = 20 w_class = WEIGHT_CLASS_SMALL sharp = TRUE @@ -205,6 +207,9 @@ name = "makeshift bolt" desc = "A sharpened metal rod that can be fired out of a crossbow." icon_state = "metal-rod" + item_state = "metal-rod" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' throwforce = 10 /obj/item/arrow/proc/modify_arrow() diff --git a/code/modules/reagents/chemistry/reagents/medicine.dm b/code/modules/reagents/chemistry/reagents/medicine.dm index 6cd40966d6d..231e7a4216e 100644 --- a/code/modules/reagents/chemistry/reagents/medicine.dm +++ b/code/modules/reagents/chemistry/reagents/medicine.dm @@ -370,6 +370,27 @@ M.reagents.remove_reagent(R.id,1) return ..() | update_flags +/datum/reagent/medicine/coaltree_extract + name = "Coaltree extract" + id = "coaltree_extract" + description = "Экстракт полученный из угледрева, выводит из организма токсины ценой больших мучений." + reagent_state = LIQUID + metabolization_rate = 0.4 * REAGENTS_METABOLISM + color = "#000000" + taste_description = "ash" + +/datum/reagent/medicine/coaltree_extract/on_mob_life(mob/living/M) + var/update_flags = STATUS_UPDATE_NONE + update_flags |= M.adjustToxLoss(-3, FALSE) + update_flags |= M.adjustBruteLoss(1, FALSE) + if(prob(10)) + to_chat(M, span_warning("Ваша кожа покрывается кровавыми волдырями.")) + if(prob(50)) + for(var/datum/reagent/R in M.reagents.reagent_list) + if(R != src) + M.reagents.remove_reagent(R.id,1) + return ..() | update_flags + /datum/reagent/medicine/omnizine name = "Omnizine" id = "omnizine" diff --git a/code/modules/surgery/encased.dm b/code/modules/surgery/encased.dm index 77fd9e7a5f6..a0a4fb5bad5 100644 --- a/code/modules/surgery/encased.dm +++ b/code/modules/surgery/encased.dm @@ -10,12 +10,14 @@ name = "saw bone" begin_sound = list( TOOL_SAW = 'sound/surgery/saw1.ogg', + /obj/item/primitive_saw = 'sound/surgery/scalpel1.ogg', TOOL_WIRECUTTER = 'sound/surgery/scalpel1.ogg', /obj/item/hatchet = 'sound/surgery/scalpel1.ogg', ) end_sound = 'sound/surgery/amputation.ogg' allowed_tools = list( TOOL_SAW = 100, + /obj/item/primitive_saw = 100, /obj/item/hatchet = 90, TOOL_WIRECUTTER = 70 ) diff --git a/code/modules/surgery/generic.dm b/code/modules/surgery/generic.dm index d639b945111..a4c9bc53116 100644 --- a/code/modules/surgery/generic.dm +++ b/code/modules/surgery/generic.dm @@ -261,11 +261,13 @@ begin_sound = list( TOOL_SAW = 'sound/surgery/saw1.ogg', /obj/item/hatchet = 'sound/surgery/scalpel1.ogg', + /obj/item/primitive_saw = 'sound/surgery/scalpel1.ogg', /obj/item/melee/arm_blade = 'sound/surgery/scalpel1.ogg', ) end_sound = 'sound/surgery/amputation.ogg' allowed_tools = list( TOOL_SAW = 100, + /obj/item/primitive_saw = 100, /obj/item/hatchet = 90, /obj/item/melee/arm_blade = 75 ) diff --git a/code/modules/surgery/organs_internal.dm b/code/modules/surgery/organs_internal.dm index 77a40efd088..58f09883216 100644 --- a/code/modules/surgery/organs_internal.dm +++ b/code/modules/surgery/organs_internal.dm @@ -812,6 +812,7 @@ allowed_tools = list( TOOL_SAW = 100, /obj/item/melee/energy/sword/cyborg/saw = 100, + /obj/item/primitive_saw = 100, /obj/item/hatchet = 90, /obj/item/wirecutters = 70 ) diff --git a/code/modules/surgery/tools.dm b/code/modules/surgery/tools.dm index 83b5c23b8f7..37be88b85f1 100644 --- a/code/modules/surgery/tools.dm +++ b/code/modules/surgery/tools.dm @@ -26,6 +26,15 @@ w_class = WEIGHT_CLASS_TINY toolspeed = 0.5 +/obj/item/retractor/primitive_retractor + name = "primitive bone retractor" + desc = "Retracts stuff." + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_retractor" + item_state = "primitive_retractor" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/hemostat name = "hemostat" desc = "You think you have seen this before." @@ -54,6 +63,15 @@ desc = "Tiny servos power a pair of pincers to stop bleeding." toolspeed = 0.5 +/obj/item/hemostat/primitive_hemostat + name = "primitive hemostat" + desc = "You think you have seen this before." + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_hemostat" + item_state = "primitive_hemostat" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/cautery name = "cautery" desc = "This stops bleeding." @@ -75,6 +93,15 @@ desc = "A heated element that cauterizes wounds." toolspeed = 0.5 +/obj/item/cautery/primitive_cautery + name = "primitive cautery" + desc = "This stops bleeding." + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_cautery" + item_state = "primitive_cautery" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/surgicaldrill name = "surgical drill" desc = "You can drill using this item. You dig?" @@ -152,6 +179,15 @@ desc = "Ultra-sharp blade attached directly to your bone for extra-accuracy." toolspeed = 0.5 +/obj/item/scalpel/primitive_scalpel + name = "primitive scalpel" + desc = "Cut, cut, and once more cut." + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_scalpel" + item_state = "primitive_scalpel" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /* * Researchable Scalpels */ @@ -241,6 +277,31 @@ w_class = WEIGHT_CLASS_SMALL toolspeed = 0.5 +/obj/item/primitive_saw + name = "primitive circular saw" + desc = "For heavy duty cutting." + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_saw" + item_state = "primitive_saw" + hitsound = 'sound/weapons/slice.ogg' + mob_throw_hit_sound = 'sound/weapons/pierce.ogg' + flags = CONDUCT + force = 15.0 + sharp = 1 + w_class = WEIGHT_CLASS_NORMAL + throwforce = 9.0 + throw_speed = 3 + throw_range = 5 + embed_chance = 20 + embedded_ignore_throwspeed_threshold = TRUE + attack_verb = list("attacked", "slashed", "sawed", "cut") + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + +/obj/item/primitive_saw/Initialize(mapload) + . = ..() + ADD_TRAIT(src, TRAIT_SURGICAL, ROUNDSTART_TRAIT) + //misc, formerly from code/defines/weapons.dm /obj/item/bonegel name = "bone gel" @@ -260,6 +321,14 @@ /obj/item/bonegel/augment toolspeed = 0.5 +/obj/item/bonegel/primitive_bonegel + name = "primitive bone gel" + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_bonegel" + item_state = "primitive_bonegel" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/FixOVein name = "FixOVein" icon = 'icons/obj/surgery.dmi' @@ -278,6 +347,14 @@ /obj/item/FixOVein/augment toolspeed = 0.5 +/obj/item/FixOVein/primitive_FixOVein + name = "primitive FixOVein" + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_fixovein" + item_state = "primitive_fixovein" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/bonesetter name = "bone setter" icon = 'icons/obj/surgery.dmi' @@ -306,6 +383,14 @@ /obj/item/bonesetter/augment toolspeed = 0.5 +/obj/item/bonesetter/primitive_bonesetter + name = "primitive bone setter" + icon = 'icons/obj/surgery.dmi' + icon_state = "primitive_bonesetter" + item_state = "primitive_bonesetter" + lefthand_file = 'icons/mob/inhands/items_lefthand.dmi' + righthand_file = 'icons/mob/inhands/items_righthand.dmi' + /obj/item/surgical_drapes name = "surgical drapes" desc = "Nanotrasen brand surgical drapes provide optimal safety and infection control." diff --git a/icons/mob/clothing/back.dmi b/icons/mob/clothing/back.dmi index 90f04c72f47..5ce2281f2e3 100644 Binary files a/icons/mob/clothing/back.dmi and b/icons/mob/clothing/back.dmi differ diff --git a/icons/mob/inhands/guns_lefthand.dmi b/icons/mob/inhands/guns_lefthand.dmi index 47e1359325f..66073ee3f6c 100644 Binary files a/icons/mob/inhands/guns_lefthand.dmi and b/icons/mob/inhands/guns_lefthand.dmi differ diff --git a/icons/mob/inhands/guns_righthand.dmi b/icons/mob/inhands/guns_righthand.dmi index 005f11926b3..d4f0f999619 100644 Binary files a/icons/mob/inhands/guns_righthand.dmi and b/icons/mob/inhands/guns_righthand.dmi differ diff --git a/icons/mob/inhands/items_lefthand.dmi b/icons/mob/inhands/items_lefthand.dmi index 96176eec0f5..5c62a174116 100755 Binary files a/icons/mob/inhands/items_lefthand.dmi and b/icons/mob/inhands/items_lefthand.dmi differ diff --git a/icons/mob/inhands/items_righthand.dmi b/icons/mob/inhands/items_righthand.dmi index 6a85c0bdcc6..947d58a8aaf 100755 Binary files a/icons/mob/inhands/items_righthand.dmi and b/icons/mob/inhands/items_righthand.dmi differ diff --git a/icons/obj/device.dmi b/icons/obj/device.dmi index de6221138cd..7c1ba685ad8 100644 Binary files a/icons/obj/device.dmi and b/icons/obj/device.dmi differ diff --git a/icons/obj/food/food.dmi b/icons/obj/food/food.dmi index ac0fda9d2df..68813b20b64 100644 Binary files a/icons/obj/food/food.dmi and b/icons/obj/food/food.dmi differ diff --git a/icons/obj/hydroponics/equipment.dmi b/icons/obj/hydroponics/equipment.dmi index 134e92be60c..a69ff80dc10 100644 Binary files a/icons/obj/hydroponics/equipment.dmi and b/icons/obj/hydroponics/equipment.dmi differ diff --git a/icons/obj/hydroponics/growing.dmi b/icons/obj/hydroponics/growing.dmi index bcaad08e1d7..d9a3c98d77c 100644 Binary files a/icons/obj/hydroponics/growing.dmi and b/icons/obj/hydroponics/growing.dmi differ diff --git a/icons/obj/hydroponics/seeds.dmi b/icons/obj/hydroponics/seeds.dmi index 4265aa70d3d..d857ca20d25 100644 Binary files a/icons/obj/hydroponics/seeds.dmi and b/icons/obj/hydroponics/seeds.dmi differ diff --git a/icons/obj/items.dmi b/icons/obj/items.dmi index f5191611985..20e6d0ae8ce 100644 Binary files a/icons/obj/items.dmi and b/icons/obj/items.dmi differ diff --git a/icons/obj/lavaland/ash_flora.dmi b/icons/obj/lavaland/ash_flora.dmi index 61c6155ca25..55f01878d2d 100644 Binary files a/icons/obj/lavaland/ash_flora.dmi and b/icons/obj/lavaland/ash_flora.dmi differ diff --git a/icons/obj/surgery.dmi b/icons/obj/surgery.dmi index 91d3fe17d43..40337084c29 100644 Binary files a/icons/obj/surgery.dmi and b/icons/obj/surgery.dmi differ diff --git a/icons/obj/tent.dmi b/icons/obj/tent.dmi new file mode 100644 index 00000000000..f74c1e71979 Binary files /dev/null and b/icons/obj/tent.dmi differ diff --git a/icons/obj/weapons/ammo.dmi b/icons/obj/weapons/ammo.dmi index 0e5c1545a30..f118d5aa100 100644 Binary files a/icons/obj/weapons/ammo.dmi and b/icons/obj/weapons/ammo.dmi differ diff --git a/icons/obj/weapons/projectile.dmi b/icons/obj/weapons/projectile.dmi index 4dd37d84e0f..08d60d81da1 100644 Binary files a/icons/obj/weapons/projectile.dmi and b/icons/obj/weapons/projectile.dmi differ diff --git a/paradise.dme b/paradise.dme index 9b96ab95328..aee205beb68 100644 --- a/paradise.dme +++ b/paradise.dme @@ -1153,6 +1153,7 @@ #include "code\game\objects\items\mixing_bowl.dm" #include "code\game\objects\items\random_items.dm" #include "code\game\objects\items\shooting_range.dm" +#include "code\game\objects\items\tent.dm" #include "code\game\objects\items\theft_items.dm" #include "code\game\objects\items\toys.dm" #include "code\game\objects\items\trash.dm" diff --git a/sound/weapons/kolotushka_smash.ogg b/sound/weapons/kolotushka_smash.ogg new file mode 100644 index 00000000000..43ba6e50b54 Binary files /dev/null and b/sound/weapons/kolotushka_smash.ogg differ