Remove separate explicit messages from all room broadcasts

This commit is contained in:
Condorra 2023-12-29 22:45:32 +11:00
parent b666165ecc
commit a68955deab
37 changed files with 228 additions and 987 deletions

View File

@ -118,11 +118,6 @@ impl QueueCommandHandler for QueueHandler {
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
dir dir
), ),
Some(&format!(
"{} closes the door to the {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
dir
)),
) )
.await?; .await?;
} }

View File

@ -97,26 +97,13 @@ impl QueueCommandHandler for QueueHandler {
} }
}; };
let msg_exp = format!( let msg = format!(
"{} prepares to cut {} from {}\n", "{} prepares to cut {} from {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&what_part, &what_part,
&corpse.display_for_sentence(true, 1, false) &corpse.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to cut {} from {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&what_part,
&corpse.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -234,12 +221,6 @@ impl QueueCommandHandler for QueueHandler {
possession_data.display, possession_data.display,
corpse.display_for_sentence(true, 1, false) corpse.display_for_sentence(true, 1, false)
), ),
Some(&format!(
"{} tries to cut the {} from {}, but only leaves a mutilated mess.\n",
&ctx.item.display_for_sentence(true, 1, true),
possession_data.display,
corpse.display_for_sentence(true, 1, false)
)),
) )
.await?; .await?;
} else { } else {
@ -258,12 +239,6 @@ impl QueueCommandHandler for QueueHandler {
possession_data.display, possession_data.display,
corpse.display_for_sentence(true, 1, false) corpse.display_for_sentence(true, 1, false)
), ),
Some(&format!(
"{} expertly cuts the {} from {}.\n",
&ctx.item.display_for_sentence(true, 1, true),
possession_data.display,
corpse.display_for_sentence(true, 1, false)
)),
) )
.await?; .await?;
} }

View File

@ -46,24 +46,12 @@ impl QueueCommandHandler for QueueHandler {
item.display_for_sentence(ctx.explicit().await?, 1, false) item.display_for_sentence(ctx.explicit().await?, 1, false)
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} prepares to drink from {}\n", "{} prepares to drink from {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to drink from {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -136,24 +124,12 @@ impl QueueCommandHandler for QueueHandler {
}; };
let how_many_drunk = how_many_to_fill.min(how_many_left.min(10000) as u16).max(1); let how_many_drunk = how_many_to_fill.min(how_many_left.min(10000) as u16).max(1);
let msg_exp = format!( let msg = format!(
"{} drinks from {}\n", "{} drinks from {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} drinks from {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
if let Some(urges) = ctx.item.urges.as_mut() { if let Some(urges) = ctx.item.urges.as_mut() {
urges.hunger.last_value = urges.hunger.value; urges.hunger.last_value = urges.hunger.value;

View File

@ -136,24 +136,12 @@ impl QueueCommandHandler for QueueHandler {
ansi!("You're wearing it - try using <bold>remove<reset> first").to_owned(), ansi!("You're wearing it - try using <bold>remove<reset> first").to_owned(),
)?; )?;
} }
let msg_exp = format!( let msg = format!(
"{} prepares to drop {}\n", "{} prepares to drop {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to drop {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -209,24 +197,12 @@ impl QueueCommandHandler for QueueHandler {
_ => (), _ => (),
} }
let msg_exp = format!( let msg = format!(
"{} drops {}\n", "{} drops {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} drops {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let mut item_mut = (*item).clone(); let mut item_mut = (*item).clone();
item_mut.location = ctx.item.location.clone(); item_mut.location = ctx.item.location.clone();
consider_expire_job_for_item(ctx.trans, &item_mut).await?; consider_expire_job_for_item(ctx.trans, &item_mut).await?;

View File

@ -44,24 +44,12 @@ impl QueueCommandHandler for QueueHandler {
item.display_for_sentence(ctx.explicit().await?, 1, false) item.display_for_sentence(ctx.explicit().await?, 1, false)
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} prepares to eat {}\n", "{} prepares to eat {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to eat {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -129,7 +117,7 @@ impl QueueCommandHandler for QueueHandler {
}; };
let how_many_eaten = how_many_to_fill.min(how_many_left).max(1); let how_many_eaten = how_many_to_fill.min(how_many_left).max(1);
let msg_exp = format!( let msg = format!(
"{} {} {}\n", "{} {} {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&(if how_many_eaten == how_many_left { &(if how_many_eaten == how_many_left {
@ -143,24 +131,7 @@ impl QueueCommandHandler for QueueHandler {
}), }),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} {} {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&(if how_many_eaten == how_many_left {
"polishes off".to_owned()
} else {
format!("eats {} bites from", how_many_eaten)
}),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
if let Some(urges) = ctx.item.urges.as_mut() { if let Some(urges) = ctx.item.urges.as_mut() {
urges.hunger.last_value = urges.hunger.value; urges.hunger.last_value = urges.hunger.value;

View File

@ -61,26 +61,13 @@ impl QueueCommandHandler for QueueHandler {
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} prepares to fill {} from {}\n", "{} prepares to fill {} from {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&to_item.display_for_sentence(true, 1, false), &to_item.display_for_sentence(true, 1, false),
&from_item.display_for_sentence(true, 1, false), &from_item.display_for_sentence(true, 1, false),
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to fill {} from {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&to_item.display_for_sentence(false, 1, false),
&from_item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -241,26 +228,13 @@ impl QueueCommandHandler for QueueHandler {
ctx.trans.save_item_model(&from_item_mut).await?; ctx.trans.save_item_model(&from_item_mut).await?;
ctx.trans.save_item_model(&to_item_mut).await?; ctx.trans.save_item_model(&to_item_mut).await?;
let msg_exp = format!( let msg = format!(
"{} fills {} from {}\n", "{} fills {} from {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&to_item.display_for_sentence(true, 1, false), &to_item.display_for_sentence(true, 1, false),
&from_item.display_for_sentence(true, 1, false), &from_item.display_for_sentence(true, 1, false),
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fills {} from {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&to_item.display_for_sentence(false, 1, false),
&from_item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(()) Ok(())
} }

View File

@ -41,24 +41,12 @@ impl QueueCommandHandler for QueueHandler {
item.display_for_sentence(ctx.explicit().await?, 1, false) item.display_for_sentence(ctx.explicit().await?, 1, false)
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} fumbles around trying to pick up {}\n", "{} fumbles around trying to pick up {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around trying to pick up {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
} }
QueueCommand::GetFromContainer { QueueCommand::GetFromContainer {
from_possession_id, from_possession_id,
@ -90,26 +78,13 @@ impl QueueCommandHandler for QueueHandler {
container.display_for_sentence(ctx.explicit().await?, 1, false), container.display_for_sentence(ctx.explicit().await?, 1, false),
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} fumbles around trying to get {} from {}.\n", "{} fumbles around trying to get {} from {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
&container.display_for_sentence(true, 1, false) &container.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around trying to get {} from {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false),
&container.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
} }
_ => user_error("Unexpected command".to_owned())?, _ => user_error("Unexpected command".to_owned())?,
}; };
@ -140,24 +115,12 @@ impl QueueCommandHandler for QueueHandler {
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} picks up {}\n", "{} picks up {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} picks up {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
(item, None) (item, None)
} }
QueueCommand::GetFromContainer { QueueCommand::GetFromContainer {
@ -190,26 +153,13 @@ impl QueueCommandHandler for QueueHandler {
container.display_for_sentence(ctx.explicit().await?, 1, false), container.display_for_sentence(ctx.explicit().await?, 1, false),
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} gets {} from {}.\n", "{} gets {} from {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
&container.display_for_sentence(true, 1, false) &container.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} gets {} from {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false),
&container.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
(item, Some(container)) (item, Some(container))
} }
_ => user_error("Unexpected command".to_owned())?, _ => user_error("Unexpected command".to_owned())?,

View File

@ -69,12 +69,6 @@ impl QueueCommandHandler for WithQueueHandler {
&ctx.item.pronouns.subject, &ctx.item.pronouns.subject,
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
), ),
Some(&format!(
"{} tries to work out what {} can make from {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&ctx.item.pronouns.subject,
&item.display_for_sentence(false, 1, false),
)),
) )
.await?; .await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
@ -261,12 +255,6 @@ impl QueueCommandHandler for FromQueueHandler {
&new_item.display_for_sentence(true, 1, false), &new_item.display_for_sentence(true, 1, false),
&ctx.item.pronouns.subject &ctx.item.pronouns.subject
), ),
Some(&format!(
"{} proudly holds up the {} {} just made.\n",
&ctx.item.display_for_sentence(false, 1, true),
&new_item.display_for_sentence(false, 1, false),
&ctx.item.pronouns.subject
)),
) )
.await?; .await?;
} }

View File

@ -113,14 +113,6 @@ impl UserVerb for Verb {
sep, sep,
&npc.pronouns.intensive &npc.pronouns.intensive
), ),
Some(&format!(
"{} {}s {} {} {}\n",
&npc.display_for_sentence(false, 1, true),
verb,
&item.display_for_sentence(false, 1, false),
sep,
&npc.pronouns.intensive
)),
) )
.await?; .await?;
} }

View File

@ -98,39 +98,23 @@ impl QueueCommandHandler for QueueHandler {
)?; )?;
} }
let mut msg_exp = format!( let mut msg = format!(
"{} starts fiddling around trying to make something", "{} starts fiddling around trying to make something",
&ctx.item.display_for_sentence(true, 1, true) &ctx.item.display_for_sentence(true, 1, true)
); );
let mut msg_nonexp = format!(
"{} starts fiddling around trying to make something",
&ctx.item.display_for_sentence(false, 1, true)
);
match bench_opt { match bench_opt {
None => {} None => {}
Some(bench) => { Some(bench) => {
msg_exp.push_str(&format!( msg.push_str(&format!(
" on {}", " on {}",
bench.display_for_sentence(true, 1, false) bench.display_for_sentence(true, 1, false)
)); ));
msg_nonexp.push_str(&format!(
" on {}",
bench.display_for_sentence(false, 1, false)
));
} }
} }
msg_exp.push_str(".\n"); msg.push_str(".\n");
msg_nonexp.push_str(".\n");
broadcast_to_room( broadcast_to_room(&ctx.trans, &ctx.item.location, None, &msg).await?;
&ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -199,12 +183,9 @@ impl QueueCommandHandler for QueueHandler {
} }
} }
let (on_what_exp, on_what_nonexp) = match bench_opt { let on_what = match bench_opt {
None => ("".to_owned(), "".to_owned()), None => "".to_owned(),
Some(bench) => ( Some(bench) => format!(" on {}", bench.display_for_sentence(true, 1, false)),
format!(" on {}", bench.display_for_sentence(true, 1, false)),
format!(" on {}", bench.display_for_sentence(false, 1, false)),
),
}; };
let craft_data = get_craft_data_for_instructions(&instructions) let craft_data = get_craft_data_for_instructions(&instructions)
@ -258,14 +239,8 @@ impl QueueCommandHandler for QueueHandler {
"{} makes a {}{}.\n", "{} makes a {}{}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&new_item.display_for_sentence(true, 1, false), &new_item.display_for_sentence(true, 1, false),
&on_what_exp &on_what
), ),
Some(&format!(
"{} makes a {}{}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&new_item.display_for_sentence(false, 1, false),
&on_what_nonexp
)),
) )
.await?; .await?;
} }

View File

@ -49,47 +49,29 @@ pub async fn announce_move(
leaving: &Item, leaving: &Item,
arriving: &Item, arriving: &Item,
) -> DResult<()> { ) -> DResult<()> {
let msg_leaving_exp = format!( let msg_leaving = format!(
"{} departs towards {}\n", "{} departs towards {}\n",
&character.display_for_sentence(true, 1, true), &character.display_for_sentence(true, 1, true),
&arriving.display &arriving.display
); );
let msg_leaving_nonexp = format!(
"{} departs towards {}\n",
character.display_for_sentence(true, 1, false),
arriving
.display_less_explicit
.as_ref()
.unwrap_or(&arriving.display)
);
broadcast_to_room( broadcast_to_room(
trans, trans,
&format!("{}/{}", &leaving.item_type, &leaving.item_code), &format!("{}/{}", &leaving.item_type, &leaving.item_code),
None, None,
&msg_leaving_exp, &msg_leaving,
Some(&msg_leaving_nonexp),
) )
.await?; .await?;
let msg_arriving_exp = format!( let msg_arriving = format!(
"{} arrives from {}\n", "{} arrives from {}\n",
&character.display_for_sentence(true, 1, true), &character.display_for_sentence(true, 1, true),
&leaving.display &leaving.display
); );
let msg_arriving_nonexp = format!(
"{} arrives from {}\n",
character.display_for_sentence(true, 1, false),
leaving
.display_less_explicit
.as_ref()
.unwrap_or(&leaving.display)
);
broadcast_to_room( broadcast_to_room(
trans, trans,
&format!("{}/{}", &arriving.item_type, &arriving.item_code), &format!("{}/{}", &arriving.item_type, &arriving.item_code),
None, None,
&msg_arriving_exp, &msg_arriving,
Some(&msg_arriving_nonexp),
) )
.await?; .await?;
Ok(()) Ok(())
@ -321,7 +303,7 @@ pub async fn handle_fall(trans: &DBTrans, faller: &mut Item, fall_dist: u64) ->
* Normal::new(1.0, 0.3)?.sample(&mut rand::thread_rng())) as i64; * Normal::new(1.0, 0.3)?.sample(&mut rand::thread_rng())) as i64;
if damage > 0 { if damage > 0 {
change_health(trans, -damage, faller, "You fell", "You fell").await?; change_health(trans, -damage, faller, "You fell").await?;
} }
let descriptor = if damage >= 30 { let descriptor = if damage >= 30 {
@ -477,22 +459,15 @@ async fn attempt_move_immediate(
}; };
ctx.item.active_climb = None; ctx.item.active_climb = None;
let descriptor = handle_fall(&ctx.trans, ctx.item, fall_dist).await?; let descriptor = handle_fall(&ctx.trans, ctx.item, fall_dist).await?;
let msg_exp = format!( let msg = format!(
"{} loses {} grip from {} metres up and {}!\n", "{} loses {} grip from {} metres up and {}!\n",
ctx.item.display_for_sentence(true, 1, true), ctx.item.display_for_sentence(true, 1, true),
ctx.item.pronouns.possessive, ctx.item.pronouns.possessive,
fall_dist, fall_dist,
&descriptor &descriptor
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &from_room, None, &msg).await?;
"{} loses {} grip from {} metres up and {}!\n", broadcast_to_room(ctx.trans, &to_room, None, &msg).await?;
ctx.item.display_for_sentence(false, 1, true),
&ctx.item.pronouns.possessive,
fall_dist,
&descriptor
);
broadcast_to_room(ctx.trans, &from_room, None, &msg_exp, Some(&msg_nonexp)).await?;
broadcast_to_room(ctx.trans, &to_room, None, &msg_exp, Some(&msg_nonexp)).await?;
ctx.item.queue.truncate(0); ctx.item.queue.truncate(0);
return Ok(got_there); return Ok(got_there);
} else if skills <= 0.0 { } else if skills <= 0.0 {
@ -566,17 +541,12 @@ async fn attempt_move_immediate(
} }
} }
} else { } else {
let msg_exp = format!( let msg = format!(
"{} starts climbing {}\n", "{} starts climbing {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&direction.describe_climb(if climb.height > 0 { "up" } else { "down" }) &direction.describe_climb(if climb.height > 0 { "up" } else { "down" })
); );
let msg_nonexp = format!( broadcast_to_room(&ctx.trans, &use_location, None, &msg).await?;
"{} starts climbing {}\n",
&ctx.item.display_for_sentence(true, 1, false),
&direction.describe_climb(if climb.height > 0 { "up" } else { "down" })
);
broadcast_to_room(&ctx.trans, &use_location, None, &msg_exp, Some(&msg_nonexp)).await?;
ctx.item.active_climb = Some(ActiveClimb { ctx.item.active_climb = Some(ActiveClimb {
..Default::default() ..Default::default()

View File

@ -76,7 +76,7 @@ impl TaskHandler for SwingShutHandler {
"The door to the {} swings shut with a click.\n", "The door to the {} swings shut with a click.\n",
&direction.describe() &direction.describe()
); );
broadcast_to_room(&ctx.trans, &room_str, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &room_str, None, &msg).await?;
if let Ok(Some(other_room)) = direction_to_item(&ctx.trans, &room_str, &direction).await { if let Ok(Some(other_room)) = direction_to_item(&ctx.trans, &room_str, &direction).await {
let msg = format!( let msg = format!(
@ -86,7 +86,7 @@ impl TaskHandler for SwingShutHandler {
.map(|d| d.describe()) .map(|d| d.describe())
.unwrap_or_else(|| "outside".to_owned()) .unwrap_or_else(|| "outside".to_owned())
); );
broadcast_to_room(&ctx.trans, &other_room.refstr(), None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &other_room.refstr(), None, &msg).await?;
} }
Ok(None) Ok(None)
@ -182,11 +182,6 @@ pub async fn attempt_open_immediate(
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
dir dir
), ),
Some(&format!(
"{} opens the door to the {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
dir
)),
) )
.await?; .await?;
} }

View File

@ -58,26 +58,13 @@ impl QueueCommandHandler for QueueHandler {
container.display_for_sentence(ctx.explicit().await?, 1, false), container.display_for_sentence(ctx.explicit().await?, 1, false),
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} fumbles around trying to put {} in {}.\n", "{} fumbles around trying to put {} in {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
&container.display_for_sentence(true, 1, false) &container.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around trying to put {} in {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false),
&container.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -139,26 +126,13 @@ impl QueueCommandHandler for QueueHandler {
})?; })?;
container_data.checker.check_place(&container, &item)?; container_data.checker.check_place(&container, &item)?;
let msg_exp = format!( let msg = format!(
"{} puts {} in {}.\n", "{} puts {} in {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
&container.display_for_sentence(true, 1, false) &container.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} puts {} in {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false),
&container.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let possession_data = match item let possession_data = match item
.possession_type .possession_type

View File

@ -107,8 +107,8 @@ impl QueueCommandHandler for QueueHandler {
} }
_ => {} _ => {}
} }
let (item, desc_exp, desc_nonexp) = match item_ref { let (item, desc) = match item_ref {
None => (None, "the floor".to_owned(), "the floor".to_owned()), None => (None, "the floor".to_owned()),
Some(item_ref) => { Some(item_ref) => {
let (item_type, item_code) = match item_ref.split_once("/") { let (item_type, item_code) = match item_ref.split_once("/") {
None => user_error("Invalid item ref in Sit command".to_owned())?, None => user_error("Invalid item ref in Sit command".to_owned())?,
@ -130,30 +130,17 @@ impl QueueCommandHandler for QueueHandler {
( (
Some(item.clone()), Some(item.clone()),
item.display_for_sentence(true, 1, false), item.display_for_sentence(true, 1, false),
item.display_for_sentence(false, 1, false),
) )
} }
} }
} }
}; };
let msg_exp = format!( let msg = format!(
"{} reclines on {}.\n", "{} reclines on {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&desc_exp &desc
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} reclines on {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&desc_nonexp
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
ctx.item.action_type = LocationActionType::Reclining(item.map(|it| it.refstr())); ctx.item.action_type = LocationActionType::Reclining(item.map(|it| it.refstr()));
recalculate_urge_growth(&ctx.trans, &mut ctx.item).await?; recalculate_urge_growth(&ctx.trans, &mut ctx.item).await?;

View File

@ -101,24 +101,12 @@ impl QueueCommandHandler for QueueHandler {
check_removeable(ctx, &item).await?; check_removeable(ctx, &item).await?;
let msg_exp = format!( let msg = format!(
"{} fumbles around trying to take off {}\n", "{} fumbles around trying to take off {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around trying to take off {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -144,24 +132,12 @@ impl QueueCommandHandler for QueueHandler {
check_removeable(ctx, &item).await?; check_removeable(ctx, &item).await?;
let msg_exp = format!( let msg = format!(
"{} removes {}\n", "{} removes {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} removes {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let mut item_mut = (*item).clone(); let mut item_mut = (*item).clone();
item_mut.action_type = LocationActionType::Normal; item_mut.action_type = LocationActionType::Normal;
item_mut.action_type_started = None; item_mut.action_type_started = None;

View File

@ -1,6 +1,5 @@
use super::{ use super::{
get_player_item_or_fail, is_likely_explicit, user_error, UResult, UserError, UserVerb, get_player_item_or_fail, user_error, UResult, UserError, UserVerb, UserVerbRef, VerbContext,
UserVerbRef, VerbContext,
}; };
#[double] #[double]
use crate::db::DBTrans; use crate::db::DBTrans;
@ -17,7 +16,6 @@ pub async fn say_to_room<'l>(
from_item: &Item, from_item: &Item,
location: &str, location: &str,
say_what: &str, say_what: &str,
is_explicit: bool,
) -> UResult<()> { ) -> UResult<()> {
let (loc_type, loc_code) = location let (loc_type, loc_code) = location
.split_once("/") .split_once("/")
@ -33,29 +31,13 @@ pub async fn say_to_room<'l>(
.to_owned(), .to_owned(),
)? )?
} }
let msg_exp = format!( let msg = format!(
ansi!("<yellow>{} says: <reset><bold>\"{}\"<reset>\n"), ansi!("<yellow>{} says: <reset><bold>\"{}\"<reset>\n"),
from_item.display_for_sentence(true, 1, true), from_item.display_for_sentence(true, 1, true),
say_what say_what
); );
let msg_lessexp = format!(
ansi!("<yellow>{} says: <reset><bold>\"{}\"<reset>\n"),
from_item.display_for_sentence(false, 1, true),
say_what
);
broadcast_to_room( broadcast_to_room(trans, location, Some(from_item), &msg).await?;
trans,
location,
Some(from_item),
&msg_exp,
if is_explicit {
None
} else {
Some(&msg_lessexp)
},
)
.await?;
Ok(()) Ok(())
} }
@ -76,14 +58,7 @@ impl UserVerb for Verb {
if player_item.death_data.is_some() { if player_item.death_data.is_some() {
user_error("Shush, the dead can't talk!".to_string())?; user_error("Shush, the dead can't talk!".to_string())?;
} }
say_to_room( say_to_room(ctx.trans, &player_item, &player_item.location, &say_what).await
ctx.trans,
&player_item,
&player_item.location,
&say_what,
is_likely_explicit(&say_what),
)
.await
} }
} }
static VERB_INT: Verb = Verb; static VERB_INT: Verb = Verb;

View File

@ -34,10 +34,6 @@ impl QueueCommandHandler for QueueHandler {
ansi!("<blue>{} starts methodically searching the area.<reset>\n"), ansi!("<blue>{} starts methodically searching the area.<reset>\n"),
ctx.item.display_for_sentence(true, 1, true), ctx.item.display_for_sentence(true, 1, true),
), ),
Some(&format!(
ansi!("<blue>{} starts methodically searching the area.<reset>\n"),
ctx.item.display_for_sentence(false, 1, true),
)),
) )
.await?; .await?;
Ok(time::Duration::from_secs(3)) Ok(time::Duration::from_secs(3))
@ -97,10 +93,6 @@ impl QueueCommandHandler for QueueHandler {
ctx.item.display_for_sentence(true, 1, true), ctx.item.display_for_sentence(true, 1, true),
found.display_for_sentence(true, 1, false), found.display_for_sentence(true, 1, false),
), ),
Some(&format!(
"{} seems to have found {} - but can't carry it so drops it on the ground.\n",
ctx.item.display_for_sentence(false, 1, true),
found.display_for_sentence(false, 1, false),)),
).await?; ).await?;
} }
_ => { _ => {
@ -113,11 +105,6 @@ impl QueueCommandHandler for QueueHandler {
ctx.item.display_for_sentence(true, 1, true), ctx.item.display_for_sentence(true, 1, true),
found.display_for_sentence(true, 1, false), found.display_for_sentence(true, 1, false),
), ),
Some(&format!(
"{} seems to have found {}.\n",
ctx.item.display_for_sentence(false, 1, true),
found.display_for_sentence(false, 1, false),
)),
) )
.await?; .await?;
found.location = ctx.item.refstr(); found.location = ctx.item.refstr();

View File

@ -99,8 +99,8 @@ impl QueueCommandHandler for QueueHandler {
LocationActionType::Sitting { .. } => user_error("You're already sitting.".to_owned())?, LocationActionType::Sitting { .. } => user_error("You're already sitting.".to_owned())?,
_ => {} _ => {}
} }
let (item, desc_exp, desc_nonexp) = match item_ref { let (item, desc) = match item_ref {
None => (None, "the floor".to_owned(), "the floor".to_owned()), None => (None, "the floor".to_owned()),
Some(item_ref) => { Some(item_ref) => {
let (item_type, item_code) = match item_ref.split_once("/") { let (item_type, item_code) = match item_ref.split_once("/") {
None => user_error("Invalid item ref in Sit command".to_owned())?, None => user_error("Invalid item ref in Sit command".to_owned())?,
@ -122,30 +122,17 @@ impl QueueCommandHandler for QueueHandler {
( (
Some(item.clone()), Some(item.clone()),
item.display_for_sentence(true, 1, false), item.display_for_sentence(true, 1, false),
item.display_for_sentence(false, 1, false),
) )
} }
} }
} }
}; };
let msg_exp = format!( let msg = format!(
"{} sits on {}.\n", "{} sits on {}.\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&desc_exp &desc
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} sits on {}.\n",
&ctx.item.display_for_sentence(false, 1, true),
&desc_nonexp
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
ctx.item.action_type = LocationActionType::Sitting(item.map(|it| it.refstr())); ctx.item.action_type = LocationActionType::Sitting(item.map(|it| it.refstr()));
recalculate_urge_growth(&ctx.trans, &mut ctx.item).await?; recalculate_urge_growth(&ctx.trans, &mut ctx.item).await?;

View File

@ -17,9 +17,8 @@ pub async fn stand_if_needed(trans: &DBTrans, who: &mut Item) -> UResult<()> {
LocationActionType::Sitting { .. } | LocationActionType::Reclining { .. } => {} LocationActionType::Sitting { .. } | LocationActionType::Reclining { .. } => {}
_ => return Ok(()), _ => return Ok(()),
} }
let msg_exp = format!("{} stands up.\n", &who.display_for_sentence(true, 1, true),); let msg = format!("{} stands up.\n", &who.display_for_sentence(true, 1, true));
let msg_nonexp = format!("{} stands up.\n", &who.display_for_sentence(false, 1, true),); broadcast_to_room(trans, &who.location, None, &msg).await?;
broadcast_to_room(trans, &who.location, None, &msg_exp, Some(&msg_nonexp)).await?;
who.action_type = LocationActionType::Normal; who.action_type = LocationActionType::Normal;
recalculate_urge_growth(trans, who).await?; recalculate_urge_growth(trans, who).await?;

View File

@ -80,7 +80,7 @@ impl QueueCommandHandler for QueueHandler {
target_name target_name
))? ))?
} }
let msg_exp = format!( let msg = format!(
"{} prepares to use {} {} on {}\n", "{} prepares to use {} {} on {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&ctx.item.pronouns.possessive, &ctx.item.pronouns.possessive,
@ -91,25 +91,7 @@ impl QueueCommandHandler for QueueHandler {
target.display_for_sentence(true, 1, false) target.display_for_sentence(true, 1, false)
} }
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} prepares to use {} {} on {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&ctx.item.pronouns.possessive,
&item.display_for_sentence(false, 0, false),
&if is_self_use {
ctx.item.pronouns.intensive.clone()
} else {
target.display_for_sentence(true, 1, false)
}
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let mut draw_level: f64 = *ctx let mut draw_level: f64 = *ctx
.item .item
.total_skills .total_skills

View File

@ -60,24 +60,12 @@ impl QueueCommandHandler for QueueHandler {
.as_ref() .as_ref()
.ok_or_else(|| UserError("You can't wear that!".to_owned()))?; .ok_or_else(|| UserError("You can't wear that!".to_owned()))?;
let msg_exp = format!( let msg = format!(
"{} fumbles around trying to put on {}\n", "{} fumbles around trying to put on {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around trying to put on {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(time::Duration::from_secs(1)) Ok(time::Duration::from_secs(1))
} }
@ -152,24 +140,12 @@ impl QueueCommandHandler for QueueHandler {
} }
} }
let msg_exp = format!( let msg = format!(
"{} wears {}\n", "{} wears {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} wears {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let mut item_mut = (*item).clone(); let mut item_mut = (*item).clone();
item_mut.action_type = LocationActionType::Worn; item_mut.action_type = LocationActionType::Worn;
item_mut.action_type_started = Some(Utc::now()); item_mut.action_type_started = Some(Utc::now());

View File

@ -37,26 +37,13 @@ impl QueueCommandHandler for QueueHandler {
if item.location != format!("player/{}", ctx.item.item_code) { if item.location != format!("player/{}", ctx.item.item_code) {
user_error("You try to wield it but realise you no longer have it".to_owned())? user_error("You try to wield it but realise you no longer have it".to_owned())?
} }
let msg_exp = format!( let msg = format!(
"{} fumbles around with {} {}\n", "{} fumbles around with {} {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&ctx.item.pronouns.possessive, &ctx.item.pronouns.possessive,
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} fumbles around with {} {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&ctx.item.pronouns.possessive,
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
let mut draw_level: f64 = ctx let mut draw_level: f64 = ctx
.item .item
.total_skills .total_skills
@ -105,24 +92,12 @@ impl QueueCommandHandler for QueueHandler {
if item.location != format!("player/{}", ctx.item.item_code) { if item.location != format!("player/{}", ctx.item.item_code) {
user_error("You try to wield it but realise you no longer have it".to_owned())? user_error("You try to wield it but realise you no longer have it".to_owned())?
} }
let msg_exp = format!( let msg = format!(
"{} wields {}\n", "{} wields {}\n",
&ctx.item.display_for_sentence(true, 1, true), &ctx.item.display_for_sentence(true, 1, true),
&item.display_for_sentence(true, 1, false) &item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &ctx.item.location, None, &msg).await?;
"{} wields {}\n",
&ctx.item.display_for_sentence(false, 1, true),
&item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&ctx.item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
ctx.trans ctx.trans
.set_exclusive_action_type_to( .set_exclusive_action_type_to(
&item, &item,

View File

@ -15,10 +15,10 @@ pub struct EffectSet {
} }
pub enum Effect { pub enum Effect {
// messagef takes player, causative item, target as the 3 parameters. Returns (explicit, non explicit) message. // messagef takes player, causative item, target as the 3 parameters. Returns message.
BroadcastMessage { BroadcastMessage {
delay_secs: u64, delay_secs: u64,
messagef: Box<dyn Fn(&Item, &Item, &Item) -> (String, String) + Sync + Send>, messagef: Box<dyn Fn(&Item, &Item, &Item) -> String + Sync + Send>,
}, },
// skill_multiplier is always positive - sign flipped for crit fails. // skill_multiplier is always positive - sign flipped for crit fails.
ChangeTargetHealth { ChangeTargetHealth {
@ -26,6 +26,6 @@ pub enum Effect {
base_effect: i64, base_effect: i64,
skill_multiplier: f64, skill_multiplier: f64,
max_effect: i64, max_effect: i64,
message: Box<dyn Fn(&Item) -> (String, String) + Sync + Send>, message: Box<dyn Fn(&Item) -> String + Sync + Send>,
}, },
} }

View File

@ -138,22 +138,11 @@ async fn start_next_attack(
victim_item: &Item, victim_item: &Item,
weapon: &WeaponData, weapon: &WeaponData,
) -> DResult<()> { ) -> DResult<()> {
let msg_exp = &(weapon let msg = &(weapon
.normal_attack .normal_attack
.start_message(&attacker_item, victim_item, true) .start_message(&attacker_item, victim_item, true)
+ ".\n"); + ".\n");
let msg_nonexp = &(weapon broadcast_to_room(ctx.trans, &attacker_item.location, None, msg).await?;
.normal_attack
.start_message(&attacker_item, victim_item, false)
+ ".\n");
broadcast_to_room(
ctx.trans,
&attacker_item.location,
None,
msg_exp,
Some(msg_nonexp),
)
.await?;
Ok(()) Ok(())
} }
@ -172,26 +161,13 @@ async fn process_attack(
.unwrap_or(0) .unwrap_or(0)
> 8000 > 8000
{ {
let msg_exp = format!( let msg = format!(
"{} looks like {} wanted to attack {}, but was too tired and stressed to do it.\n", "{} looks like {} wanted to attack {}, but was too tired and stressed to do it.\n",
attacker_item.display_for_sentence(true, 1, true), attacker_item.display_for_sentence(true, 1, true),
attacker_item.pronouns.subject, attacker_item.pronouns.subject,
victim_item.display_for_sentence(true, 1, false), victim_item.display_for_sentence(true, 1, false),
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &attacker_item.location, None, &msg).await?;
"{} looks like {} wanted to attack {}, but was too tired and stressed to do it.\n",
attacker_item.display_for_sentence(false, 1, true),
attacker_item.pronouns.subject,
victim_item.display_for_sentence(false, 1, false),
);
broadcast_to_room(
ctx.trans,
&attacker_item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
match attacker_item.active_combat.as_mut() { match attacker_item.active_combat.as_mut() {
Some(ac) if ac.attack_mode != AttackMode::NORMAL => { Some(ac) if ac.attack_mode != AttackMode::NORMAL => {
@ -240,24 +216,12 @@ async fn process_attack(
change_stress_considering_cool(&ctx.trans, attacker_item, 100).await?; change_stress_considering_cool(&ctx.trans, attacker_item, 100).await?;
if dodge_result > attack_result { if dodge_result > attack_result {
let msg_exp = format!( let msg = format!(
"{} dodges out of the way of {}'s attack.\n", "{} dodges out of the way of {}'s attack.\n",
victim_item.display_for_sentence(true, 1, true), victim_item.display_for_sentence(true, 1, true),
attacker_item.display_for_sentence(true, 1, false) attacker_item.display_for_sentence(true, 1, false)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &attacker_item.location, None, &msg).await?;
"{} dodges out of the way of {}'s attack.\n",
victim_item.display_for_sentence(false, 1, true),
attacker_item.display_for_sentence(false, 1, false)
);
broadcast_to_room(
ctx.trans,
&attacker_item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
match attacker_item.active_combat.as_mut() { match attacker_item.active_combat.as_mut() {
Some(ac) => ac.attack_mode = AttackMode::NORMAL, Some(ac) => ac.attack_mode = AttackMode::NORMAL,
None => {} None => {}
@ -298,38 +262,16 @@ async fn process_attack(
&part, &part,
) )
.await? as i64; .await? as i64;
let msg_exp = attack.success_message(&attacker_item, victim_item, &part, true); let msg = attack.success_message(&attacker_item, victim_item, &part, true);
let msg_nonexp = attack.success_message(&attacker_item, victim_item, &part, false);
if actual_damage == 0 { if actual_damage == 0 {
let msg_exp = format!( let msg = format!(
"{}'s attack bounces off {}'s {}.\n", "{}'s attack bounces off {}'s {}.\n",
&attacker_item.display_for_sentence(true, 1, true), &attacker_item.display_for_sentence(true, 1, true),
&victim_item.display_for_sentence(true, 1, false), &victim_item.display_for_sentence(true, 1, false),
&part.display(victim_item.sex.clone()) &part.display(victim_item.sex.clone())
); );
let msg_nonexp = format!( broadcast_to_room(&ctx.trans, &victim_item.location, None, &msg).await?;
"{}'s attack bounces off {}'s {}.\n", } else if change_health(ctx.trans, -actual_damage, victim_item, &msg).await? {
attacker_item.display_for_sentence(false, 1, true),
victim_item.display_for_sentence(false, 1, false),
&part.display(None)
);
broadcast_to_room(
&ctx.trans,
&victim_item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
} else if change_health(
ctx.trans,
-actual_damage,
victim_item,
&msg_exp,
&msg_nonexp,
)
.await?
{
ctx.trans.save_item_model(victim_item).await?; ctx.trans.save_item_model(victim_item).await?;
return Ok(true); return Ok(true);
} }
@ -375,26 +317,13 @@ async fn process_feint(
.unwrap_or(0) .unwrap_or(0)
> 8000 > 8000
{ {
let msg_exp = format!( let msg = format!(
"{} looks like {} wanted to feint {}, but was too tired and stressed to do it.\n", "{} looks like {} wanted to feint {}, but was too tired and stressed to do it.\n",
attacker_item.display_for_sentence(true, 1, true), attacker_item.display_for_sentence(true, 1, true),
attacker_item.pronouns.subject, attacker_item.pronouns.subject,
victim_item.display_for_sentence(true, 1, false), victim_item.display_for_sentence(true, 1, false),
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &attacker_item.location, None, &msg).await?;
"{} looks like {} wanted to feint {}, but was too tired and stressed to do it.\n",
attacker_item.display_for_sentence(false, 1, true),
attacker_item.pronouns.subject,
victim_item.display_for_sentence(false, 1, false),
);
broadcast_to_room(
ctx.trans,
&attacker_item.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
match attacker_item.active_combat.as_mut() { match attacker_item.active_combat.as_mut() {
Some(ac) => { Some(ac) => {
ac.attack_mode = AttackMode::NORMAL; ac.attack_mode = AttackMode::NORMAL;
@ -426,12 +355,6 @@ async fn process_feint(
&attacker_item.pronouns.object, &attacker_item.pronouns.object,
&attacker_item.pronouns.intensive, &attacker_item.pronouns.intensive,
), ),
Some(&format!(
"{} seems to have pulled off the feint so poorly {} confused {}!\n",
&attacker_item.display_for_sentence(false, 1, true),
&attacker_item.pronouns.object,
&attacker_item.pronouns.intensive,
)),
) )
.await?; .await?;
run_effects( run_effects(
@ -460,11 +383,6 @@ async fn process_feint(
&victim_item.display_for_sentence(true, 1, true), &victim_item.display_for_sentence(true, 1, true),
&attacker_item.display_for_sentence(true, 1, false), &attacker_item.display_for_sentence(true, 1, false),
), ),
Some(&format!(
"{} is confused by {}'s antics!\n",
&victim_item.display_for_sentence(false, 1, true),
&attacker_item.display_for_sentence(false, 1, false),
)),
) )
.await?; .await?;
run_effects( run_effects(
@ -488,11 +406,6 @@ async fn process_feint(
&victim_item.display_for_sentence(true, 1, true), &victim_item.display_for_sentence(true, 1, true),
&attacker_item.display_for_sentence(true, 1, false) &attacker_item.display_for_sentence(true, 1, false)
), ),
Some(&format!(
"{} doesn't seem to have fallen for {}'s unenlightened attempt at a feint.\n",
&victim_item.display_for_sentence(false, 1, true),
&attacker_item.display_for_sentence(false, 1, false)
)),
) )
.await?; .await?;
return Ok(false); return Ok(false);
@ -608,8 +521,7 @@ pub async fn change_health(
trans: &DBTrans, trans: &DBTrans,
change: i64, change: i64,
victim: &mut Item, victim: &mut Item,
reason_exp: &str, reason: &str,
reason_nonexp: &str,
) -> DResult<bool> { ) -> DResult<bool> {
let maxh = max_health(victim); let maxh = max_health(victim);
let new_health = ((victim.health as i64 + change).max(0) as u64).min(maxh); let new_health = ((victim.health as i64 + change).max(0) as u64).min(maxh);
@ -621,19 +533,15 @@ pub async fn change_health(
} else { } else {
ansi!("<red>") ansi!("<red>")
}; };
let msg_exp = format!( let msg = format!(
ansi!("[ {}{}<reset> <bold>{}/{}<reset> ] {}.\n"), ansi!("[ {}{}<reset> <bold>{}/{}<reset> ] {}.\n"),
colour, colour,
change, change,
new_health, new_health,
max_health(&victim), max_health(&victim),
reason_exp reason
); );
let msg_nonexp = format!( broadcast_to_room(trans, &victim.location, None, &msg).await?;
ansi!("[ {}{}<reset> <bold>{}/{}<reset> ] {}.\n"),
colour, change, new_health, maxh, reason_nonexp
);
broadcast_to_room(trans, &victim.location, None, &msg_exp, Some(&msg_nonexp)).await?;
victim.health = new_health; victim.health = new_health;
if new_health == 0 { if new_health == 0 {
handle_death(trans, victim).await?; handle_death(trans, victim).await?;
@ -739,15 +647,11 @@ pub async fn consider_reward_for(
} }
pub async fn handle_death(trans: &DBTrans, whom: &mut Item) -> DResult<()> { pub async fn handle_death(trans: &DBTrans, whom: &mut Item) -> DResult<()> {
let msg_exp = format!( let msg = format!(
ansi!("<red>{} stiffens and collapses dead.<reset>\n"), ansi!("<red>{} stiffens and collapses dead.<reset>\n"),
&whom.display_for_sentence(true, 1, true) &whom.display_for_sentence(true, 1, true)
); );
let msg_nonexp = format!( broadcast_to_room(trans, &whom.location, None, &msg).await?;
ansi!("<red>{} stiffens and collapses dead.<reset>\n"),
&whom.display_for_sentence(false, 1, true)
);
broadcast_to_room(trans, &whom.location, None, &msg_exp, Some(&msg_nonexp)).await?;
whom.death_data = Some(DeathData { whom.death_data = Some(DeathData {
parts_remaining: species_info_map() parts_remaining: species_info_map()
@ -1002,8 +906,7 @@ pub async fn start_attack_mut(
by_whom: &mut Item, by_whom: &mut Item,
to_whom: &mut Item, to_whom: &mut Item,
) -> UResult<()> { ) -> UResult<()> {
let mut msg_exp = String::new(); let mut msg = String::new();
let mut msg_nonexp = String::new();
let mut verb: String = "attacks".to_string(); let mut verb: String = "attacks".to_string();
match by_whom.action_type { match by_whom.action_type {
LocationActionType::Sitting { .. } | LocationActionType::Reclining { .. } => { LocationActionType::Sitting { .. } | LocationActionType::Reclining { .. } => {
@ -1037,31 +940,17 @@ pub async fn start_attack_mut(
_ => {} _ => {}
} }
msg_exp.push_str(&format!( msg.push_str(&format!(
ansi!("<red>{} {} {}.<reset>\n"), ansi!("<red>{} {} {}.<reset>\n"),
&by_whom.display_for_sentence(true, 1, true), &by_whom.display_for_sentence(true, 1, true),
verb, verb,
&to_whom.display_for_sentence(true, 1, false) &to_whom.display_for_sentence(true, 1, false)
)); ));
msg_nonexp.push_str(&format!(
ansi!("<red>{} {} {}.<reset>\n"),
&by_whom.display_for_sentence(false, 1, true),
verb,
&to_whom.display_for_sentence(false, 1, false)
));
let (_, wielded) = what_wielded(trans, &Arc::new(by_whom.clone())).await?; let (_, wielded) = what_wielded(trans, &Arc::new(by_whom.clone())).await?;
msg_exp.push_str(&(wielded.normal_attack.start_message(by_whom, to_whom, true) + ".\n")); msg.push_str(&(wielded.normal_attack.start_message(by_whom, to_whom, true) + ".\n"));
msg_nonexp.push_str(&(wielded.normal_attack.start_message(by_whom, to_whom, false) + ".\n"));
broadcast_to_room( broadcast_to_room(trans, &by_whom.location, None::<&Item>, &msg).await?;
trans,
&by_whom.location,
None::<&Item>,
&msg_exp,
Some(msg_nonexp.as_str()),
)
.await?;
let ac = by_whom let ac = by_whom
.active_combat .active_combat
@ -1164,9 +1053,8 @@ pub async fn switch_to_power_attack(ctx: &VerbContext<'_>, who: &Arc<Item>) -> U
None => user_error("They seem to be gone!".to_owned())?, None => user_error("They seem to be gone!".to_owned())?,
Some(v) => v, Some(v) => v,
}; };
let msg_exp = pow_att.start_message(who, &to_whom, true) + ".\n"; let msg = pow_att.start_message(who, &to_whom, true) + ".\n";
let msg_nonexp = pow_att.start_message(who, &to_whom, false) + ".\n"; broadcast_to_room(ctx.trans, &who.location, None, &msg).await?;
broadcast_to_room(ctx.trans, &who.location, None, &msg_exp, Some(&msg_nonexp)).await?;
let mut who_mut = (**who).clone(); let mut who_mut = (**who).clone();
who_mut.active_combat.as_mut().map(|ac| { who_mut.active_combat.as_mut().map(|ac| {
@ -1259,15 +1147,11 @@ pub async fn switch_to_feint(ctx: &VerbContext<'_>, who: &Arc<Item>) -> UResult<
}, },
]; ];
let feint = feints.iter().choose(&mut thread_rng()).unwrap(); let feint = feints.iter().choose(&mut thread_rng()).unwrap();
let msg_exp = feint( let msg = feint(
&who.display_for_sentence(true, 1, true), &who.display_for_sentence(true, 1, true),
&to_whom.display_for_sentence(true, 1, false), &to_whom.display_for_sentence(true, 1, false),
); );
let msg_nonexp = feint( broadcast_to_room(ctx.trans, &who.location, None, &msg).await?;
&who.display_for_sentence(false, 1, true),
&to_whom.display_for_sentence(false, 1, false),
);
broadcast_to_room(ctx.trans, &who.location, None, &msg_exp, Some(&msg_nonexp)).await?;
let mut who_mut = (**who).clone(); let mut who_mut = (**who).clone();
who_mut.active_combat.as_mut().map(|ac| { who_mut.active_combat.as_mut().map(|ac| {
@ -1339,22 +1223,11 @@ impl TaskHandler for RotCorpseTaskHandler {
}; };
destroy_container(ctx.trans, &corpse).await?; destroy_container(ctx.trans, &corpse).await?;
let msg_exp = format!( let msg = format!(
"{} rots away to nothing.\n", "{} rots away to nothing.\n",
corpse.display_for_sentence(true, 1, true) corpse.display_for_sentence(true, 1, true)
); );
let msg_nonexp = format!( broadcast_to_room(ctx.trans, &corpse.location, None, &msg).await?;
"{} rots away to nothing.\n",
corpse.display_for_sentence(false, 1, true)
);
broadcast_to_room(
ctx.trans,
&corpse.location,
None,
&msg_exp,
Some(&msg_nonexp),
)
.await?;
Ok(None) Ok(None)
} }
} }

View File

@ -7,26 +7,21 @@ pub async fn broadcast_to_room(
trans: &DBTrans, trans: &DBTrans,
location: &str, location: &str,
from_item: Option<&Item>, from_item: Option<&Item>,
message_explicit_ok: &str, message: &str,
message_nonexplicit: Option<&str>,
) -> DResult<()> { ) -> DResult<()> {
for item in trans.find_items_by_location(location).await? { for item in trans.find_items_by_location(location).await? {
if item.item_type != "player" || item.death_data.is_some() { if item.item_type != "player" || item.death_data.is_some() {
continue; continue;
} }
if let Some((session, session_dat)) = trans.find_session_for_player(&item.item_code).await? if let Some(exclude) = from_item {
{ if exclude.item_code == item.item_code && exclude.item_type == item.item_type {
if session_dat.less_explicit_mode continue;
&& Some(&item.item_code) != from_item.map(|i| &i.item_code)
{
if let Some(msg) = message_nonexplicit {
trans.queue_for_session(&session, Some(msg)).await?;
} }
return Ok(());
} }
trans if let Some((session, _session_dat)) =
.queue_for_session(&session, Some(message_explicit_ok)) trans.find_session_for_player(&item.item_code).await?
.await?; {
trans.queue_for_session(&session, Some(message)).await?;
} }
} }
Ok(()) Ok(())

View File

@ -26,14 +26,12 @@ pub struct DelayedHealthEffect {
magnitude: i64, magnitude: i64,
delay: u64, delay: u64,
message: String, message: String,
message_nonexp: String,
} }
#[derive(Serialize, Deserialize, Clone, Debug, Eq, PartialEq, Ord, PartialOrd)] #[derive(Serialize, Deserialize, Clone, Debug, Eq, PartialEq, Ord, PartialOrd)]
pub struct DelayedMessageEffect { pub struct DelayedMessageEffect {
delay: u64, delay: u64,
message: String, message: String,
message_nonexp: String,
} }
pub struct DelayedHealthTaskHandler; pub struct DelayedHealthTaskHandler;
@ -73,20 +71,10 @@ impl TaskHandler for DelayedHealthTaskHandler {
match item_effect_series.1.pop_front() { match item_effect_series.1.pop_front() {
None => Ok(None), None => Ok(None),
Some(DelayedHealthEffect { Some(DelayedHealthEffect {
magnitude, magnitude, message, ..
message,
message_nonexp,
..
}) => { }) => {
let mut item_mut = (*item).clone(); let mut item_mut = (*item).clone();
change_health( change_health(ctx.trans, magnitude, &mut item_mut, &message).await?;
ctx.trans,
magnitude,
&mut item_mut,
&message,
&message_nonexp,
)
.await?;
ctx.trans.save_item_model(&item_mut).await?; ctx.trans.save_item_model(&item_mut).await?;
Ok(item_effect_series Ok(item_effect_series
.1 .1
@ -135,19 +123,8 @@ impl TaskHandler for DelayedMessageTaskHandler {
} }
match item_effect_series.1.pop_front() { match item_effect_series.1.pop_front() {
None => Ok(None), None => Ok(None),
Some(DelayedMessageEffect { Some(DelayedMessageEffect { message, .. }) => {
message, broadcast_to_room(&ctx.trans, &item.location, None, &message).await?;
message_nonexp,
..
}) => {
broadcast_to_room(
&ctx.trans,
&item.location,
None,
&message,
Some(&message_nonexp),
)
.await?;
Ok(item_effect_series Ok(item_effect_series
.1 .1
.front() .front()
@ -214,20 +191,18 @@ pub async fn run_effects(
delay_secs, delay_secs,
messagef, messagef,
} => { } => {
let (msg_exp, msg_nonexp) = messagef( let msg = messagef(
player, player,
item, item,
target.as_ref().map(|t| &**t).unwrap_or(player), target.as_ref().map(|t| &**t).unwrap_or(player),
); );
if *delay_secs == 0 { if *delay_secs == 0 {
broadcast_to_room(trans, &player.location, None, &msg_exp, Some(&msg_nonexp)) broadcast_to_room(trans, &player.location, None, &msg).await?;
.await?;
} else { } else {
dispel_time_secs = dispel_time_secs.max(*delay_secs); dispel_time_secs = dispel_time_secs.max(*delay_secs);
let fx = DelayedMessageEffect { let fx = DelayedMessageEffect {
delay: *delay_secs, delay: *delay_secs,
message: msg_exp, message: msg,
message_nonexp: msg_nonexp,
}; };
let actual_target: &mut Item = *target.as_mut().unwrap_or(&mut player); let actual_target: &mut Item = *target.as_mut().unwrap_or(&mut player);
target_message_series target_message_series
@ -248,14 +223,13 @@ pub async fn run_effects(
} => { } => {
let health_impact = let health_impact =
(*base_effect + ((skill_multiplier * level) as i64)).min(*max_effect) as i64; (*base_effect + ((skill_multiplier * level) as i64)).min(*max_effect) as i64;
let (msg, msg_nonexp) = message(target.as_ref().map(|t| &**t).unwrap_or(player)); let msg = message(target.as_ref().map(|t| &**t).unwrap_or(player));
if *delay_secs == 0 { if *delay_secs == 0 {
change_health( change_health(
trans, trans,
health_impact, health_impact,
*target.as_mut().unwrap_or(&mut player), *target.as_mut().unwrap_or(&mut player),
&msg, &msg,
&msg_nonexp,
) )
.await?; .await?;
} else { } else {
@ -265,7 +239,6 @@ pub async fn run_effects(
magnitude: health_impact, magnitude: health_impact,
delay: *delay_secs, delay: *delay_secs,
message: msg, message: msg,
message_nonexp: msg_nonexp,
}; };
target_health_series target_health_series
.entry(format!("{}/{}", target_it.item_type, target_it.item_code)) .entry(format!("{}/{}", target_it.item_type, target_it.item_code))
@ -376,105 +349,84 @@ pub fn default_effects_for_type() -> &'static BTreeMap<EffectType, EffectSet> {
effects: vec![ effects: vec![
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 0, delay_secs: 0,
messagef: Box::new(|_player, _item, target| ( messagef: Box::new(|_player, _item, target|
format!(ansi!("<red>You notice that {} has a fresh gaping wound that looks like it's about to {}!<reset>\n"), format!(ansi!("<red>You notice that {} has a fresh gaping wound that looks like it's about to {}!<reset>\n"),
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
if target.species == SpeciesType::Robot { "leak coolant" } else { "bleed" } if target.species == SpeciesType::Robot { "leak coolant" } else { "bleed" }
), )
format!(ansi!("<red>You notice that {} has a fresh gaping wound that looks like it's about to {}!<reset>\n"), )
target.display_for_sentence(false, 1, false),
if target.species == SpeciesType::Robot { "leak coolant" } else { "bleed" }
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 10, delay_secs: 10,
base_effect: -12, base_effect: -12,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -12, max_effect: -12,
message: Box::new(|target| ( message: Box::new(|target|
format!("{} pulses from {}'s wound", format!("{} pulses from {}'s wound",
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" }, if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("{} pulses from {}'s wound", )
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 20, delay_secs: 20,
base_effect: -10, base_effect: -10,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -10, max_effect: -10,
message: Box::new(|target| ( message: Box::new(|target|
format!("{} pulses from {}'s wound", format!("{} pulses from {}'s wound",
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" }, if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("{} pulses from {}'s wound", )
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 30, delay_secs: 30,
base_effect: -8, base_effect: -8,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -8, max_effect: -8,
message: Box::new(|target| ( message: Box::new(|target|
format!("{} pulses from {}'s wound", format!("{} pulses from {}'s wound",
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" }, if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("{} pulses from {}'s wound", )
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 40, delay_secs: 40,
base_effect: -6, base_effect: -6,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -6, max_effect: -6,
message: Box::new(|target| ( message: Box::new(|target|
format!("{} pulses from {}'s wound", format!("{} pulses from {}'s wound",
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" }, if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("{} pulses from {}'s wound", )
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 50, delay_secs: 50,
base_effect: -4, base_effect: -4,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -4, max_effect: -4,
message: Box::new(|target| ( message: Box::new(|target|
format!("{} pulses from {}'s wound", format!("{} pulses from {}'s wound",
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" }, if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("{} pulses from {}'s wound", )
if target.species == SpeciesType::Robot { "Coolant" } else { "Blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 60, delay_secs: 60,
base_effect: -2, base_effect: -2,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: -2, max_effect: -2,
message: Box::new(|target| ( message: Box::new(|target|
format!("A final tiny drop of {} oozes from {}'s wound as it heals", format!("A final tiny drop of {} oozes from {}'s wound as it heals",
if target.species == SpeciesType::Robot { "coolant" } else { "blood" }, if target.species == SpeciesType::Robot { "coolant" } else { "blood" },
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
), )
format!("A final tiny drop of {} oozes from {}'s wound as it clots", )
if target.species == SpeciesType::Robot { "coolant" } else { "blood" },
target.display_for_sentence(false, 1, false),
)))
}, },
], ],
}, },
@ -483,26 +435,20 @@ pub fn default_effects_for_type() -> &'static BTreeMap<EffectType, EffectSet> {
effects: vec![ effects: vec![
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 0, delay_secs: 0,
messagef: Box::new(|_player, _item, target| ( messagef: Box::new(|_player, _item, target|
format!(ansi!("<blue>{} is stunned!<reset>\n"), format!(ansi!("<blue>{} is stunned!<reset>\n"),
target.display_for_sentence(true, 1, true), target.display_for_sentence(true, 1, true),
), )
format!(ansi!("<blue>{} is stunned!<reset>\n"), )
target.display_for_sentence(false, 1, true))
))
}, },
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 30, delay_secs: 30,
messagef: Box::new(|_player, _item, target| ( messagef: Box::new(|_player, _item, target|
format!(ansi!("<blue>{} seems to have returned to {} senses!<reset>\n"), format!(ansi!("<blue>{} seems to have returned to {} senses!<reset>\n"),
target.display_for_sentence(true, 1, true), target.display_for_sentence(true, 1, true),
&target.pronouns.object, &target.pronouns.object,
),
format!(ansi!("<blue>{} seems to have returned to {} senses!<reset>\n"),
target.display_for_sentence(false, 1, true),
&target.pronouns.object,
) )
)) )
}, },
] ]
} }

View File

@ -265,7 +265,7 @@ impl TaskHandler for ShareTaskHandler {
} }
}; };
let msg = format!(ansi!("<magenta>{}<reset>\n"), &msg); let msg = format!(ansi!("<magenta>{}<reset>\n"), &msg);
broadcast_to_room(&ctx.trans, &p1.location, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &p1.location, None, &msg).await?;
let mut p1_mut = (*p1).clone(); let mut p1_mut = (*p1).clone();
let mut p2_mut = (*p2).clone(); let mut p2_mut = (*p2).clone();
@ -638,7 +638,6 @@ pub async fn start_conversation(
&acceptor.display_for_sentence(false, 1, true), &acceptor.display_for_sentence(false, 1, true),
&acceptor.pronouns.subject &acceptor.pronouns.subject
), ),
None,
) )
.await?; .await?;
@ -708,7 +707,6 @@ pub async fn stop_conversation_mut(
leave_description, leave_description,
&partner_mut.display_for_sentence(true, 1, false) &partner_mut.display_for_sentence(true, 1, false)
), ),
None,
) )
.await?; .await?;
@ -1078,7 +1076,7 @@ pub async fn change_conversational_style(
topic.display_readable(), topic.display_readable(),
&alt_topics_str &alt_topics_str
); );
broadcast_to_room(&ctx.trans, &player_item.location, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &player_item.location, None, &msg).await?;
Ok(()) Ok(())
} }
@ -1128,7 +1126,7 @@ pub async fn change_conversation_topic(
other_player.display_for_sentence(true, 1, false), other_player.display_for_sentence(true, 1, false),
topic.display_readable(), topic.display_readable(),
); );
broadcast_to_room(&ctx.trans, &player_item.location, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &player_item.location, None, &msg).await?;
Ok(()) Ok(())
} }
@ -1170,7 +1168,7 @@ pub async fn change_conversation_intensity(
other_player.display_for_sentence(true, 1, false), other_player.display_for_sentence(true, 1, false),
intensity.display_readable(), intensity.display_readable(),
); );
broadcast_to_room(&ctx.trans, &player_item.location, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &player_item.location, None, &msg).await?;
Ok(()) Ok(())
} }

View File

@ -473,6 +473,6 @@ pub async fn crit_fail_penalty_for_skill(
.floor() .floor()
.max(1.0); .max(1.0);
let final_damage = soak_damage(trans, &dist, who, actual_damage_presoak, &part).await?; let final_damage = soak_damage(trans, &dist, who, actual_damage_presoak, &part).await?;
change_health(trans, -final_damage as i64, who, &msg, &msg).await?; change_health(trans, -final_damage as i64, who, &msg).await?;
Ok(()) Ok(())
} }

View File

@ -101,7 +101,7 @@ pub async fn hunger_changed(trans: &DBTrans, who: &Item) -> DResult<()> {
} }
} else { } else {
if who.species == SpeciesType::Human { if who.species == SpeciesType::Human {
match say_to_room(&trans, who, &who.location, msg, false).await { match say_to_room(&trans, who, &who.location, msg).await {
Ok(_) => Ok(()), Ok(_) => Ok(()),
Err(SystemError(e)) => Err(e), Err(SystemError(e)) => Err(e),
Err(UserError(_)) => Ok(()), Err(UserError(_)) => Ok(()),
@ -183,7 +183,7 @@ pub async fn thirst_changed(trans: &DBTrans, who: &Item) -> DResult<()> {
.await?; .await?;
} }
} else { } else {
match say_to_room(&trans, who, &who.location, msg, false).await { match say_to_room(&trans, who, &who.location, msg).await {
Ok(_) => Ok(()), Ok(_) => Ok(()),
Err(SystemError(e)) => Err(e), Err(SystemError(e)) => Err(e),
Err(UserError(_)) => Ok(()), Err(UserError(_)) => Ok(()),

View File

@ -53,8 +53,7 @@ pub trait NPCMessageHandler {
#[derive(Clone, Debug)] #[derive(Clone, Debug)]
pub enum NPCSayType { pub enum NPCSayType {
// Bool is true if it should be filtered for less-explicit. FromFixedList(Vec<&'static str>),
FromFixedList(Vec<(bool, &'static str)>),
} }
#[derive(Clone, Debug)] #[derive(Clone, Debug)]
@ -393,7 +392,7 @@ impl TaskHandler for NPCSayTaskHandler {
return Ok(None); return Ok(None);
} }
let (is_explicit, say_what) = match &say_info.talk_type { let say_what = match &say_info.talk_type {
NPCSayType::FromFixedList(l) => { NPCSayType::FromFixedList(l) => {
let mut rng = thread_rng(); let mut rng = thread_rng();
match l[..].choose(&mut rng) { match l[..].choose(&mut rng) {
@ -404,20 +403,12 @@ impl TaskHandler for NPCSayTaskHandler {
); );
return Ok(None); return Ok(None);
} }
Some(r) => r.clone(), Some(r) => r,
} }
} }
}; };
match say_to_room( match say_to_room(ctx.trans, &npc_item, &npc_item.location, say_what).await {
ctx.trans,
&npc_item,
&npc_item.location,
say_what,
is_explicit,
)
.await
{
Ok(()) => {} Ok(()) => {}
Err(CommandHandlingError::UserError(e)) => { Err(CommandHandlingError::UserError(e)) => {
info!( info!(

View File

@ -260,7 +260,7 @@ impl NPCMessageHandler for DoorbotMsgHandler {
again, ready for the next candidate for the club - so I suggest you enter \ again, ready for the next candidate for the club - so I suggest you enter \
before it closes.\"<reset>. As if by magic, the puzzle resets back to \ before it closes.\"<reset>. As if by magic, the puzzle resets back to \
its starting state, and the door swings open with a creak.\n"); its starting state, and the door swings open with a creak.\n");
broadcast_to_room(&ctx.trans, &target.location, None, msg, Some(msg)).await?; broadcast_to_room(&ctx.trans, &target.location, None, msg).await?;
ctx.trans ctx.trans
.upsert_task(&Task { .upsert_task(&Task {
meta: TaskMeta { meta: TaskMeta {
@ -286,7 +286,7 @@ impl NPCMessageHandler for DoorbotMsgHandler {
"Doorbot moves a disc to tower {}. The screen now shows: {}.\n", "Doorbot moves a disc to tower {}. The screen now shows: {}.\n",
to, &descr to, &descr
); );
broadcast_to_room(&ctx.trans, &target.location, None, &msg, Some(&msg)).await?; broadcast_to_room(&ctx.trans, &target.location, None, &msg).await?;
room_item.details_dyn_suffix = Some(descr); room_item.details_dyn_suffix = Some(descr);
ctx.trans.save_item_model(&room_item).await?; ctx.trans.save_item_model(&room_item).await?;
@ -375,22 +375,22 @@ pub fn npc_list() -> Vec<NPC> {
say_code: "babble", say_code: "babble",
frequency_secs: 120, frequency_secs: 120,
talk_type: FromFixedList(vec!( talk_type: FromFixedList(vec!(
(false, "I wish I could get into the secret hackers club - I heard they have a machine that hacks your wristpad to make you a super smart dork."), ("I wish I could get into the secret hackers club - I heard they have a machine that hacks your wristpad to make you a super smart dork."),
(false, "The basement here is pretty dangerous with all those robots."), ("The basement here is pretty dangerous with all those robots."),
(false, "I overhead a real dork bragging about how he managed to get all four rings onto the rightmost virtual peg. No idea what that was about!"), ("I overhead a real dork bragging about how he managed to get all four rings onto the rightmost virtual peg. No idea what that was about!"),
(false, "Why is it that all the dorks around here keep whispering stuff to each other about Towers of Hanoi?"), ("Why is it that all the dorks around here keep whispering stuff to each other about Towers of Hanoi?"),
)) ))
}; };
let killbot_stdsay = NPCSayInfo { let killbot_stdsay = NPCSayInfo {
say_code: "babble", say_code: "babble",
frequency_secs: 20, frequency_secs: 20,
talk_type: FromFixedList(vec!( talk_type: FromFixedList(vec![
(false, "My mission is to EXTERMINATE"), "My mission is to EXTERMINATE",
(false, "Intruder kill mode active"), "Intruder kill mode active",
(false, "Recoverable Error: Preset Kill Limit not set. Treating as unlimited"), "Recoverable Error: Preset Kill Limit not set. Treating as unlimited",
(false, "404 action module STUN not found. Falling back to action KILL underscore WITH underscore EXTREME underscore PREJUDICE"), "404 action module STUN not found. Falling back to action KILL underscore WITH underscore EXTREME underscore PREJUDICE",
)) ])
}; };
fn geek_gender_word(pronouns: &NPCPronounType) -> &'static str { fn geek_gender_word(pronouns: &NPCPronounType) -> &'static str {

View File

@ -19,16 +19,16 @@ pub fn npc_list() -> Vec<NPC> {
let melbs_citizen_stdsay = NPCSayInfo { let melbs_citizen_stdsay = NPCSayInfo {
say_code: "babble", say_code: "babble",
frequency_secs: 120, frequency_secs: 120,
talk_type: FromFixedList(vec!( talk_type: FromFixedList(vec![
(false, "I'm so sick of being cloned."), "I'm so sick of being cloned.",
(false, "I hope I don't die again today."), "I hope I don't die again today.",
(false, "I wish the so-called king would do something about the damned zombies everywhere."), "I wish the so-called king would do something about the damned zombies everywhere.",
(true, "I earn so many credits making babies for the body factory - it literally pays my bills."), "I heard in the olden days before the empire babies grew up naturally instead of being taken away to the body factory.",
(false, "I know people hated the empire, but I kind of wish it was still intact - it was a lot better than what we have now."), "I know people hated the empire, but I kind of wish it was still intact - it was a lot better than what we have now.",
(false, "I wish there wasn't so much radiation outside of Melbs CBD."), "I wish there wasn't so much radiation outside of Melbs CBD.",
(false, "I heard about a guy who went to a special place somewhere around here, and there was a machine that enhanced his wristpad and gave him basically superpowers."), "I heard about a guy who went to a special place somewhere around here, and there was a machine that enhanced his wristpad and gave him basically superpowers.",
(false, "The damn vampire movement... they are all so sneaky, and I never know when they are going to come for my blood."), "The damn vampire movement... they are all so sneaky, and I never know when they are going to come for my blood.",
)) ])
}; };
from_yaml_str::<Vec<Citizen>>(include_str!("melbs_citizen.yaml")) from_yaml_str::<Vec<Citizen>>(include_str!("melbs_citizen.yaml"))

View File

@ -50,34 +50,23 @@ impl HireHandler for RoboporterHandler {
} else { } else {
50 - stats.total_count 50 - stats.total_count
}; };
let mut msg_exp = String::new(); let mut msg = String::new();
let mut msg_nonexp = String::new(); let desc = target.display_for_sentence(true, 1, true);
let desc_exp = target.display_for_sentence(true, 1, true);
let desc_nonexp = target.display_for_sentence(false, 1, true);
for item in trans.find_items_by_location(&target.refstr()).await? { for item in trans.find_items_by_location(&target.refstr()).await? {
if remaining_space > 0 { if remaining_space > 0 {
msg_exp.push_str(&format!( msg.push_str(&format!(
"{} unloads {} from {}\n", "{} unloads {} from {}\n",
&desc_exp, &desc,
&item.display_for_sentence(true, 1, false), &item.display_for_sentence(true, 1, false),
&target.pronouns.intensive &target.pronouns.intensive
)); ));
msg_nonexp.push_str(&format!(
"{} unloads {} from {}\n",
&desc_nonexp,
&item.display_for_sentence(false, 1, false),
&target.pronouns.intensive
));
let mut item_mut = (*item).clone(); let mut item_mut = (*item).clone();
item_mut.location = target.location.clone(); item_mut.location = target.location.clone();
trans.save_item_model(&item_mut).await?; trans.save_item_model(&item_mut).await?;
remaining_space -= 1; remaining_space -= 1;
} else { } else {
msg_exp.push_str(&format!("{} unloads {} - but since there isn't enough space to put it down, flicks it into the Roboporter's onboard furnace compartment!\n", msg.push_str(&format!("{} unloads {} - but since there isn't enough space to put it down, flicks it into the Roboporter's onboard furnace compartment!\n",
&desc_exp, &item.display_for_sentence(true, 1, false), &desc, &item.display_for_sentence(true, 1, false),
));
msg_nonexp.push_str(&format!("{} unloads {} - but since there isn't enough space to put it down, flicks it into the Roboporter's onboard furnace compartment!\n",
&desc_exp, &item.display_for_sentence(false, 1, false),
)); ));
recursively_destroy_or_move_item(trans, &item).await?; recursively_destroy_or_move_item(trans, &item).await?;
} }
@ -89,22 +78,12 @@ impl HireHandler for RoboporterHandler {
{ {
if return_to != &target.location { if return_to != &target.location {
target.location = return_to.to_owned(); target.location = return_to.to_owned();
msg_exp.push_str( msg.push_str(
&format!("By some marvel of modern engineering, {} disappears in a puff of smoke and is gone.\n", &format!("By some marvel of modern engineering, {} disappears in a puff of smoke and is gone.\n",
desc_exp)); desc));
msg_nonexp.push_str(
&format!("By some marvel of modern engineering, {} disappears in a puff of smoke and is gone.\n",
desc_nonexp));
} }
} }
broadcast_to_room( broadcast_to_room(trans, &old_location, None, msg.as_str()).await?;
trans,
&old_location,
None,
msg_exp.as_str(),
Some(msg_nonexp.as_str()),
)
.await?;
Ok(()) Ok(())
} }
} }

View File

@ -101,11 +101,6 @@ impl ArglessHandler for CorpLicenceHandler {
&player.display_for_sentence(true, 1, true), &player.display_for_sentence(true, 1, true),
name name
), ),
Some(&format!(
"{} signs a contract establishing {} as a corp\n",
&player.display_for_sentence(false, 1, true),
name
)),
) )
.await?; .await?;
let corp_id = ctx let corp_id = ctx

View File

@ -91,12 +91,6 @@ impl InstallHandler for ScanLockInstall {
&direction.describe(), &direction.describe(),
&what.display_for_sentence(true, 1, false) &what.display_for_sentence(true, 1, false)
), ),
Some(&format!(
"{} bangs the door to the {} as he installs {} on it.\n",
&player.display_for_sentence(false, 1, true),
&direction.describe(),
&what.display_for_sentence(false, 1, false)
)),
) )
.await?; .await?;
Ok(()) Ok(())
@ -140,13 +134,6 @@ impl InstallHandler for ScanLockInstall {
&what.display_for_sentence(true, 1, false), &what.display_for_sentence(true, 1, false),
extra_text extra_text
), ),
Some(&format!(
"{} bangs the door to the {} as he uninstalls {} from it{}.\n",
&player.display_for_sentence(false, 1, true),
&direction.describe(),
&what.display_for_sentence(false, 1, false),
extra_text
)),
) )
.await?; .await?;
Ok(()) Ok(())

View File

@ -30,7 +30,7 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
effects: vec!( effects: vec!(
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 0, delay_secs: 0,
messagef: Box::new(|player, _item, target| ( messagef: Box::new(|player, _item, target|
format!( format!(
"{} attempts to heal {} with a trauma kit, but fucks it up badly\n", "{} attempts to heal {} with a trauma kit, but fucks it up badly\n",
&player.display_for_sentence(true, 1, true), &player.display_for_sentence(true, 1, true),
@ -40,28 +40,17 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
target.display_for_sentence(true, 1, false) target.display_for_sentence(true, 1, false)
} }
), ),
format!("{} attempts to heal {} with a trauma kit, but messes it up badly\n", )
&player.display_for_sentence(false, 1, true),
&if target.item_type == player.item_type && target.item_code == player.item_code {
player.pronouns.intensive.clone()
} else {
target.display_for_sentence(false, 1, false)
}
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 0, base_effect: -2, skill_multiplier: -3.0, delay_secs: 0, base_effect: -2, skill_multiplier: -3.0,
max_effect: -5, max_effect: -5,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"Fuck! The trauma kit makes {}'s condition worse",
target.display_for_sentence(true, 1, false)),
format!( format!(
"The trauma kit makes {}'s condition worse", "Fuck! The trauma kit makes {}'s condition worse",
target.display_for_sentence(false, 1, false) target.display_for_sentence(true, 1, false))
) )
))
} }
) )
}), }),
@ -70,7 +59,7 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
effects: vec!( effects: vec!(
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 0, delay_secs: 0,
messagef: Box::new(|player, _item, target| ( messagef: Box::new(|player, _item, target|
format!( format!(
"{} attempts unsuccessfully to heal {} with a trauma kit\n", "{} attempts unsuccessfully to heal {} with a trauma kit\n",
&player.display_for_sentence(true, 1, true), &player.display_for_sentence(true, 1, true),
@ -79,15 +68,8 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
} else { } else {
target.display_for_sentence(true, 1, false) target.display_for_sentence(true, 1, false)
} }
), )
format!("{} attempts unsuccessfully to heal {} with a trauma kit\n", )
&player.display_for_sentence(false, 1, true),
&if target.item_type == player.item_type && target.item_code == player.item_code {
player.pronouns.intensive.clone()
} else {
target.display_for_sentence(false, 1, false)
}
)))
}, },
) )
}), }),
@ -96,7 +78,7 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
effects: vec!( effects: vec!(
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 0, delay_secs: 0,
messagef: Box::new(|player, _item, target| ( messagef: Box::new(|player, _item, target|
format!( format!(
"{} expertly heals {} with a trauma kit\n", "{} expertly heals {} with a trauma kit\n",
&player.display_for_sentence(true, 1, true), &player.display_for_sentence(true, 1, true),
@ -105,31 +87,19 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
} else { } else {
target.display_for_sentence(true, 1, false) target.display_for_sentence(true, 1, false)
} }
), )
format!("{} expertly heals {} with a trauma kit\n", )
&player.display_for_sentence(false, 1, true),
&if target.item_type == player.item_type && target.item_code == player.item_code {
player.pronouns.intensive.clone()
} else {
target.display_for_sentence(false, 1, false)
}
)))
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 0, base_effect: 2, skill_multiplier: 8.0, delay_secs: 0, base_effect: 2, skill_multiplier: 8.0,
max_effect: 10, max_effect: 10,
message: Box::new( message: Box::new(
|target| |target|
(format!( format!(
"FUUUCK! It hurts {}, but also starts to soothe {}", "FUUUCK! It hurts {}, but also starts to soothe {}",
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
&target.pronouns.object &target.pronouns.object
), )
format!(
"It hurts {}, but also starts to soothe {}",
target.display_for_sentence(true, 1, false),
&target.pronouns.object
))
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -137,16 +107,11 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 9, max_effect: 9,
message: Box::new( message: Box::new(
|target| |target|
(format!( format!(
"FUUUCK! It hurts {}, but also starts to soothe {}", "FUUUCK! It hurts {}, but also starts to soothe {}",
target.display_for_sentence(true, 1, false), target.display_for_sentence(true, 1, false),
&target.pronouns.object &target.pronouns.object
), )
format!(
"It hurts {}, but also starts to soothe {}",
target.display_for_sentence(true, 1, false),
&target.pronouns.object
))
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -154,14 +119,10 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 7, max_effect: 7,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"The bandages soothe {}'s wounds",
target.display_for_sentence(true, 1, false),
),
format!( format!(
"The bandages soothe {}'s wounds", "The bandages soothe {}'s wounds",
target.display_for_sentence(false, 1, false), target.display_for_sentence(true, 1, false),
)) )
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -169,14 +130,10 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 6, max_effect: 6,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"The bandages soothe {}'s wounds",
target.display_for_sentence(true, 1, false),
),
format!( format!(
"The bandages soothe {}'s wounds", "The bandages soothe {}'s wounds",
target.display_for_sentence(false, 1, false), target.display_for_sentence(true, 1, false),
)) )
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -184,14 +141,10 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 4, max_effect: 4,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"The bandages soothe {}'s wounds",
target.display_for_sentence(true, 1, false),
),
format!( format!(
"The bandages soothe {}'s wounds", "The bandages soothe {}'s wounds",
target.display_for_sentence(false, 1, false), target.display_for_sentence(true, 1, false),
)) )
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -199,14 +152,10 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 3, max_effect: 3,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"The bandages soothe {}'s wounds",
target.display_for_sentence(true, 1, false),
),
format!( format!(
"The bandages soothe {}'s wounds", "The bandages soothe {}'s wounds",
target.display_for_sentence(false, 1, false), target.display_for_sentence(true, 1, false),
)) )
) )
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
@ -214,27 +163,20 @@ pub fn data() -> &'static Vec<(PossessionType, PossessionData)> {
max_effect: 2, max_effect: 2,
message: Box::new( message: Box::new(
|target| |target|
(format!(
"The bandages soothe {}'s wounds",
target.display_for_sentence(true, 1, false),
),
format!( format!(
"The bandages soothe {}'s wounds", "The bandages soothe {}'s wounds",
target.display_for_sentence(false, 1, false), target.display_for_sentence(true, 1, false),
)) )
) )
}, },
Effect::BroadcastMessage { Effect::BroadcastMessage {
delay_secs: 60, delay_secs: 60,
messagef: Box::new(|_player, _item, target| ( messagef: Box::new(|_player, _item, target|
format!( format!(
"The bandages wrapping {} crumble and fall away, their healing capabilities fully expended.\n", "The bandages wrapping {} crumble and fall away, their healing capabilities fully expended.\n",
target.display_for_sentence(true, 1, false) target.display_for_sentence(true, 1, false)
), )
format!( )
"The bandages wrapping {} crumble and fall away, their healing capabilities fully expended.\n",
target.display_for_sentence(false, 1, false)
)))
} }
), ),
}), }),

View File

@ -121,48 +121,28 @@ impl TaskHandler for SeePatientTaskHandler {
base_effect: 10, base_effect: 10,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: 10, max_effect: 10,
message: Box::new(|_item| { message: Box::new(|_item| "That feels better".to_owned()),
(
"That feels better".to_owned(),
"That feels better".to_owned(),
)
}),
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 10, delay_secs: 10,
base_effect: 9, base_effect: 9,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: 10, max_effect: 10,
message: Box::new(|_item| { message: Box::new(|_item| "That feels better".to_owned()),
(
"That feels better".to_owned(),
"That feels better".to_owned(),
)
}),
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 20, delay_secs: 20,
base_effect: 8, base_effect: 8,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: 10, max_effect: 10,
message: Box::new(|_item| { message: Box::new(|_item| "That feels better".to_owned()),
(
"That feels better".to_owned(),
"That feels better".to_owned(),
)
}),
}, },
Effect::ChangeTargetHealth { Effect::ChangeTargetHealth {
delay_secs: 30, delay_secs: 30,
base_effect: 7, base_effect: 7,
skill_multiplier: 0.0, skill_multiplier: 0.0,
max_effect: 10, max_effect: 10,
message: Box::new(|_item| { message: Box::new(|_item| "That feels better".to_owned()),
(
"That feels better".to_owned(),
"That feels better".to_owned(),
)
}),
}, },
], ],
}, },