veloren/world/src/sim/location.rs
2021-09-24 23:18:07 +02:00

69 lines
2.4 KiB
Rust

use core::hash::BuildHasherDefault;
use fxhash::FxHasher64;
use hashbrown::HashSet;
use rand::{seq::SliceRandom, Rng};
use vek::*;
#[derive(Clone, Debug)]
pub struct Location {
pub(crate) name: String,
pub(crate) center: Vec2<i32>,
pub(crate) kingdom: Option<Kingdom>,
// We use this hasher (FxHasher64) because
// (1) we don't care about DDOS attacks (ruling out SipHash);
// (2) we care about determinism across computers (ruling out AAHash);
// (3) we have 8-byte keys (for which FxHash is fastest).
pub(crate) neighbours: HashSet<u64, BuildHasherDefault<FxHasher64>>,
}
impl Location {
pub fn generate(center: Vec2<i32>, rng: &mut impl Rng) -> Self {
Self {
name: generate_name(rng),
center,
kingdom: None,
neighbours: HashSet::default(),
}
}
pub fn name(&self) -> &str { &self.name }
pub fn kingdom(&self) -> Option<&Kingdom> { self.kingdom.as_ref() }
}
#[derive(Clone, Debug)]
pub struct Kingdom {
#[allow(dead_code)]
region_name: String,
}
fn generate_name(rng: &mut impl Rng) -> String {
let firstsyl = [
"Eri", "Val", "Gla", "Wilde", "Cold", "Deep", "Dura", "Ester", "Fay", "Dark", "West",
"East", "North", "South", "Ray", "Eri", "Dal", "Som", "Sommer", "Black", "Iron", "Grey",
"Hel", "Gal", "Mor", "Lo", "Nil", "Bel", "Lor", "Gold", "Red", "Marble", "Mana", "Gar",
"Mountain", "Red", "Cheo", "Far", "High",
];
let mid = ["ka", "se", "au", "da", "di"];
let tails = [
/* "mill", */ "ben", "sel", "dori", "theas", "dar", "bur", "to", "vis", "ten",
"stone", "tiva", "id", "and", "or", "el", "ond", "ia", "eld", "ald", "aft", "ift", "ity",
"well", "oll", "ill", "all", "wyn", "light", " Hill", "lin", "mont", "mor", "cliff", "rok",
"den", "mi", "rock", "glenn", "rovi", "lea", "gate", "view", "ley", "wood", "ovia",
"cliff", "marsh", "kor", "ice", /* "river", */ "acre", "venn", "crest", "field",
"vale", "spring", " Vale", "grasp", "fel", "fall", "grove", "wyn", "edge",
];
let mut name = String::new();
if rng.gen() {
name += firstsyl.choose(rng).unwrap();
name += mid.choose(rng).unwrap();
name += tails.choose(rng).unwrap();
name
} else {
name += firstsyl.choose(rng).unwrap();
name += tails.choose(rng).unwrap();
name
}
}