Cannot block with the incorrect card, Duke blocks foreign aid not income
This commit is contained in:
parent
30fcafe293
commit
443e3a91c5
49
src/lib.rs
49
src/lib.rs
@ -29,7 +29,7 @@ impl Card {
|
||||
}
|
||||
pub fn blocks_action(self, action: Action) -> bool {
|
||||
matches!((self, action),
|
||||
(Duke, Income) |
|
||||
(Duke, ForeignAid) |
|
||||
(Captain, Steal) |
|
||||
(Ambassador, Steal) |
|
||||
(Contessa, Assassinate))
|
||||
@ -243,12 +243,18 @@ impl Game {
|
||||
target: block.target,
|
||||
})),
|
||||
ResMode::Target => match agents[block.target.unwrap()].choose_block_card(&block) {
|
||||
Some(card) => Ok(Phase::BlockChallenge(phase::BlockChallenge {
|
||||
blocker: block.target.unwrap(),
|
||||
block_card: card,
|
||||
action: block.action,
|
||||
target: block.target,
|
||||
})),
|
||||
Some(card) => {
|
||||
if card.blocks_action(block.action) {
|
||||
Ok(Phase::BlockChallenge(phase::BlockChallenge {
|
||||
blocker: block.target.unwrap(),
|
||||
block_card: card,
|
||||
action: block.action,
|
||||
target: block.target,
|
||||
}))
|
||||
} else {
|
||||
Err("Card does not block action")
|
||||
}
|
||||
},
|
||||
None => Ok(Phase::Resolution(phase::Resolution {
|
||||
action: block.action,
|
||||
target: block.target,
|
||||
@ -257,12 +263,16 @@ impl Game {
|
||||
ResMode::Anyone => {
|
||||
for id in self.turn_iterator() {
|
||||
if let Some(card) = agents[id].choose_block_card(&block) {
|
||||
return Ok(Phase::BlockChallenge(phase::BlockChallenge {
|
||||
blocker: id,
|
||||
block_card: card,
|
||||
action: block.action,
|
||||
target: block.target,
|
||||
}))
|
||||
if card.blocks_action(block.action) {
|
||||
return Ok(Phase::BlockChallenge(phase::BlockChallenge {
|
||||
blocker: id,
|
||||
block_card: card,
|
||||
action: block.action,
|
||||
target: block.target,
|
||||
}))
|
||||
} else {
|
||||
return Err("Card does not block action")
|
||||
}
|
||||
}
|
||||
}
|
||||
Ok(Phase::Resolution(phase::Resolution {
|
||||
@ -512,6 +522,19 @@ mod test {
|
||||
}))
|
||||
);
|
||||
}
|
||||
|
||||
// Test bad block card
|
||||
{
|
||||
let mut game = game.clone();
|
||||
assert!(
|
||||
game.block(phase::Block {
|
||||
action: ForeignAid,
|
||||
target: None,
|
||||
}, &[&non_blocking_agent, &ambassador_block_agent, &non_blocking_agent])
|
||||
.is_err()
|
||||
);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
Loading…
Reference in New Issue
Block a user