Add more roads content.

This commit is contained in:
Condorra 2023-01-02 15:39:55 +11:00
parent 6d155c3e68
commit 82dfac1cf5
3 changed files with 269 additions and 24 deletions

View File

@ -336,8 +336,8 @@ impl DBTrans {
item_code: &str) -> DResult<()> { item_code: &str) -> DResult<()> {
self.pg_trans()?.query( self.pg_trans()?.query(
"DELETE FROM items WHERE details->>'is_static' = 'true' AND \ "DELETE FROM items WHERE details->>'is_static' = 'true' AND \
details->>'item_type' = {} AND \ details->>'item_type' = $1 AND \
details->>'item_code' = {}", details->>'item_code' = $2",
&[&item_type, &item_code]).await?; &[&item_type, &item_code]).await?;
Ok(()) Ok(())
} }

View File

@ -55,9 +55,11 @@ async fn refresh_static_items(pool: &DBPool) -> DResult<()> {
(type_group.items)().map(|x| (x.item_code.to_owned(), x)).collect(); (type_group.items)().map(|x| (x.item_code.to_owned(), x)).collect();
let expected_set: BTreeSet<String> = expected_items.keys().map(|x|x.to_owned()).collect(); let expected_set: BTreeSet<String> = expected_items.keys().map(|x|x.to_owned()).collect();
for unwanted_item in existing_items.difference(&expected_set) { for unwanted_item in existing_items.difference(&expected_set) {
info!("Deleting item {:?}", unwanted_item);
tx.delete_static_items_by_code(type_group.item_type, unwanted_item).await?; tx.delete_static_items_by_code(type_group.item_type, unwanted_item).await?;
} }
for new_item_code in expected_set.difference(&existing_items) { for new_item_code in expected_set.difference(&existing_items) {
info!("Creating item {:?}", new_item_code);
tx.create_item(&(expected_items.get(new_item_code) tx.create_item(&(expected_items.get(new_item_code)
.unwrap().initial_item)()).await?; .unwrap().initial_item)()).await?;
} }

View File

@ -243,7 +243,7 @@ pub fn room_list() -> &'static Vec<Room> {
exits: vec!( exits: vec!(
Exit { Exit {
direction: Direction::WEST, direction: Direction::WEST,
target: ExitTarget::Custom("room/melbs_kingst_500"), target: ExitTarget::Custom("room/melbs_kingst_50"),
exit_type: ExitType::Free exit_type: ExitType::Free
}) })
}, },
@ -252,12 +252,12 @@ pub fn room_list() -> &'static Vec<Room> {
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!(), secondary_zones: vec!(),
code: "melbs_kingst_200", code: "melbs_kingst_latrobest",
name: "King Street - 200 block", name: "King Street & Latrobe St",
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>##<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side", description: "A wide road (5 lanes each way) intersects a narrower 3 lane road. Both have been rather poorly maintained. Potholes dot the ashphalt road.",
description_less_explicit: None, description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: -3, z: 0 }, grid_coords: GridCoords { x: 1, y: -5, z: 0 },
exits: vec!( exits: vec!(
Exit { Exit {
direction: Direction::SOUTH, direction: Direction::SOUTH,
@ -269,8 +269,52 @@ pub fn room_list() -> &'static Vec<Room> {
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!(), secondary_zones: vec!(),
code: "melbs_kingst_300", code: "melbs_kingst_10",
name: "King Street - 300 block", name: "King Street - 10 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: -4, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_20",
name: "King Street - 20 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: -3, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_30",
name: "King Street - 30 block",
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side", description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None, description_less_explicit: None,
@ -291,10 +335,10 @@ pub fn room_list() -> &'static Vec<Room> {
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!(), secondary_zones: vec!(),
code: "melbs_kingst_400", code: "melbs_kingst_lonsdalest",
name: "King Street - 400 block", name: "King Street & Lonsdale St",
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>##<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side", description: "A wide road (5 lanes each way) intersects a narrower 2 lane each way road. Both have been rather poorly maintained. Potholes dot the ashphalt road",
description_less_explicit: None, description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: -1, z: 0 }, grid_coords: GridCoords { x: 1, y: -1, z: 0 },
exits: vec!( exits: vec!(
@ -310,6 +354,29 @@ pub fn room_list() -> &'static Vec<Room> {
}, },
) )
}, },
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_40",
name: ansi!("King Street - 40 block"),
short: ansi!("<yellow>||<reset>"),
description: ansi!(
"A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side"),
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 0, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!( secondary_zones: vec!(
@ -319,13 +386,13 @@ pub fn room_list() -> &'static Vec<Room> {
grid_coords: GridCoords { x: 1, y: 0, z: 0 } grid_coords: GridCoords { x: 1, y: 0, z: 0 }
} }
), ),
code: "melbs_kingst_500", code: "melbs_kingst_50",
name: ansi!("King Street - 500 block"), name: ansi!("King Street - 50 block"),
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>||<reset>"),
description: ansi!( description: ansi!(
"A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side"), "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side"),
description_less_explicit: None, description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 0, z: 0 }, grid_coords: GridCoords { x: 1, y: 1, z: 0 },
exits: vec!( exits: vec!(
Exit { Exit {
direction: Direction::EAST, direction: Direction::EAST,
@ -347,12 +414,12 @@ pub fn room_list() -> &'static Vec<Room> {
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!(), secondary_zones: vec!(),
code: "melbs_kingst_600", code: "melbs_kingst_60",
name: "King Street - 600 block", name: "King Street - 60 block",
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side", description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None, description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 1, z: 0 }, grid_coords: GridCoords { x: 1, y: 2, z: 0 },
exits: vec!( exits: vec!(
Exit { Exit {
direction: Direction::NORTH, direction: Direction::NORTH,
@ -369,12 +436,188 @@ pub fn room_list() -> &'static Vec<Room> {
Room { Room {
zone: "melbs", zone: "melbs",
secondary_zones: vec!(), secondary_zones: vec!(),
code: "melbs_kingst_700", code: "melbs_kingst_bourkest",
name: "King Street - 700 block", name: "King Street & Bourke St",
short: ansi!("<yellow>##<reset>"),
description: "A wide road (5 lanes each way) intersects a slightly narrower 4-lane road with wide but heavily cracked concrete footpaths. Potholes dot the ashphalt road.",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 3, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_70",
name: "King Street - 70 block",
short: ansi!("<yellow>||<reset>"), short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side", description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None, description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 2, z: 0 }, grid_coords: GridCoords { x: 1, y: 4, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_80",
name: "King Street - 80 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 5, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_90",
name: "King Street - 90 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 6, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_collinsst",
name: "King Street & Collins St",
short: ansi!("<yellow>##<reset>"),
description: "A wide road (5 lanes each way) intersects another wide 4-lane road. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 7, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_100",
name: "King Street - 100 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 8, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_110",
name: "King Street - 110 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 9, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_120",
name: "King Street - 120 block",
short: ansi!("<yellow>||<reset>"),
description: "A wide road (5 lanes each way) that has been rather poorly maintained. Potholes dot the ashphalt road, while cracks line the footpaths on either side",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 10, z: 0 },
exits: vec!(
Exit {
direction: Direction::NORTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
Exit {
direction: Direction::SOUTH,
target: ExitTarget::UseGPS,
exit_type: ExitType::Free
},
)
},
Room {
zone: "melbs",
secondary_zones: vec!(),
code: "melbs_kingst_flinderst",
name: "King Street & Flinders St",
short: ansi!("<yellow>##<reset>"),
description: "A wide road (5 lanes each way) intersects a wide road with rusted tram tracks in the middle. Potholes dot the ashphalt road.",
description_less_explicit: None,
grid_coords: GridCoords { x: 1, y: 11, z: 0 },
exits: vec!( exits: vec!(
Exit { Exit {
direction: Direction::NORTH, direction: Direction::NORTH,
@ -382,7 +625,7 @@ pub fn room_list() -> &'static Vec<Room> {
exit_type: ExitType::Free exit_type: ExitType::Free
}, },
) )
}, },
).into_iter().collect()) ).into_iter().collect())
} }