From 82dfac1cf5cd6178794fe1bf563ac3313b395d78 Mon Sep 17 00:00:00 2001 From: Shagnor Date: Mon, 2 Jan 2023 15:39:55 +1100 Subject: [PATCH] Add more roads content. --- blastmud_game/src/db.rs | 4 +- blastmud_game/src/static_content.rs | 2 + blastmud_game/src/static_content/room.rs | 287 +++++++++++++++++++++-- 3 files changed, 269 insertions(+), 24 deletions(-) diff --git a/blastmud_game/src/db.rs b/blastmud_game/src/db.rs index d8887e6..b89e5f4 100644 --- a/blastmud_game/src/db.rs +++ b/blastmud_game/src/db.rs @@ -336,8 +336,8 @@ impl DBTrans { item_code: &str) -> DResult<()> { self.pg_trans()?.query( "DELETE FROM items WHERE details->>'is_static' = 'true' AND \ - details->>'item_type' = {} AND \ - details->>'item_code' = {}", + details->>'item_type' = $1 AND \ + details->>'item_code' = $2", &[&item_type, &item_code]).await?; Ok(()) } diff --git a/blastmud_game/src/static_content.rs b/blastmud_game/src/static_content.rs index 857ac7c..320797d 100644 --- a/blastmud_game/src/static_content.rs +++ b/blastmud_game/src/static_content.rs @@ -55,9 +55,11 @@ async fn refresh_static_items(pool: &DBPool) -> DResult<()> { (type_group.items)().map(|x| (x.item_code.to_owned(), x)).collect(); let expected_set: BTreeSet = expected_items.keys().map(|x|x.to_owned()).collect(); 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?; } 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) .unwrap().initial_item)()).await?; } diff --git a/blastmud_game/src/static_content/room.rs b/blastmud_game/src/static_content/room.rs index 722a2ad..5fe8bd5 100644 --- a/blastmud_game/src/static_content/room.rs +++ b/blastmud_game/src/static_content/room.rs @@ -243,7 +243,7 @@ pub fn room_list() -> &'static Vec { exits: vec!( Exit { direction: Direction::WEST, - target: ExitTarget::Custom("room/melbs_kingst_500"), + target: ExitTarget::Custom("room/melbs_kingst_50"), exit_type: ExitType::Free }) }, @@ -252,12 +252,12 @@ pub fn room_list() -> &'static Vec { Room { zone: "melbs", secondary_zones: vec!(), - code: "melbs_kingst_200", - name: "King Street - 200 block", - short: ansi!("||"), - 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", + code: "melbs_kingst_latrobest", + name: "King Street & Latrobe St", + short: ansi!("##"), + 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, - grid_coords: GridCoords { x: 1, y: -3, z: 0 }, + grid_coords: GridCoords { x: 1, y: -5, z: 0 }, exits: vec!( Exit { direction: Direction::SOUTH, @@ -269,8 +269,52 @@ pub fn room_list() -> &'static Vec { Room { zone: "melbs", secondary_zones: vec!(), - code: "melbs_kingst_300", - name: "King Street - 300 block", + code: "melbs_kingst_10", + name: "King Street - 10 block", + short: ansi!("||"), + 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!("||"), + 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!("||"), 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, @@ -291,10 +335,10 @@ pub fn room_list() -> &'static Vec { Room { zone: "melbs", secondary_zones: vec!(), - code: "melbs_kingst_400", - name: "King Street - 400 block", - short: ansi!("||"), - 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", + code: "melbs_kingst_lonsdalest", + name: "King Street & Lonsdale St", + short: ansi!("##"), + 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, grid_coords: GridCoords { x: 1, y: -1, z: 0 }, exits: vec!( @@ -310,6 +354,29 @@ pub fn room_list() -> &'static Vec { }, ) }, + Room { + zone: "melbs", + secondary_zones: vec!(), + code: "melbs_kingst_40", + name: ansi!("King Street - 40 block"), + short: 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"), + 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 { zone: "melbs", secondary_zones: vec!( @@ -319,13 +386,13 @@ pub fn room_list() -> &'static Vec { grid_coords: GridCoords { x: 1, y: 0, z: 0 } } ), - code: "melbs_kingst_500", - name: ansi!("King Street - 500 block"), + code: "melbs_kingst_50", + name: ansi!("King Street - 50 block"), short: 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"), description_less_explicit: None, - grid_coords: GridCoords { x: 1, y: 0, z: 0 }, + grid_coords: GridCoords { x: 1, y: 1, z: 0 }, exits: vec!( Exit { direction: Direction::EAST, @@ -347,12 +414,12 @@ pub fn room_list() -> &'static Vec { Room { zone: "melbs", secondary_zones: vec!(), - code: "melbs_kingst_600", - name: "King Street - 600 block", + code: "melbs_kingst_60", + name: "King Street - 60 block", short: ansi!("||"), 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: 1, z: 0 }, + grid_coords: GridCoords { x: 1, y: 2, z: 0 }, exits: vec!( Exit { direction: Direction::NORTH, @@ -369,12 +436,188 @@ pub fn room_list() -> &'static Vec { Room { zone: "melbs", secondary_zones: vec!(), - code: "melbs_kingst_700", - name: "King Street - 700 block", + code: "melbs_kingst_bourkest", + name: "King Street & Bourke St", + short: ansi!("##"), + 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!("||"), 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: 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!("||"), + 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!("||"), + 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!("##"), + 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!("||"), + 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!("||"), + 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!("||"), + 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!("##"), + 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!( Exit { direction: Direction::NORTH, @@ -382,7 +625,7 @@ pub fn room_list() -> &'static Vec { exit_type: ExitType::Free }, ) - }, + }, ).into_iter().collect()) }