author | alfadur |
Wed, 22 Mar 2023 18:53:00 +0300 | |
changeset 15960 | ab57c0d81748 |
parent 15591 | 4b2f3228f13b |
child 15968 | ce47259d5c86 |
permissions | -rw-r--r-- |
15095 | 1 |
use super::types::ClientId; |
13810 | 2 |
use bitflags::*; |
12128 | 3 |
|
14478 | 4 |
bitflags! { |
15554 | 5 |
pub struct ClientFlags: u8 { |
13493
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
6 |
const IS_ADMIN = 0b0000_0001; |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
7 |
const IS_MASTER = 0b0000_0010; |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
8 |
const IS_READY = 0b0000_0100; |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
9 |
const IS_IN_GAME = 0b0000_1000; |
15591 | 10 |
const IS_CONTRIBUTOR = 0b0001_0000; |
11 |
const HAS_SUPER_POWER = 0b0010_0000; |
|
12 |
const IS_REGISTERED = 0b0100_0000; |
|
15960
ab57c0d81748
add a client moderator flag just to commit something
alfadur
parents:
15591
diff
changeset
|
13 |
const IS_MODERATOR = 0b1000_0000; |
13529 | 14 |
|
15 |
const NONE = 0b0000_0000; |
|
16 |
const DEFAULT = Self::NONE.bits; |
|
13493
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
17 |
} |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
18 |
} |
13486 | 19 |
|
15096 | 20 |
pub struct HwClient { |
13119
1e39b8749072
separated the server logic from all the async io mess.
alfadur
parents:
12853
diff
changeset
|
21 |
pub id: ClientId, |
12852 | 22 |
pub room_id: Option<usize>, |
12141 | 23 |
pub nick: String, |
13486 | 24 |
pub protocol_number: u16, |
13493
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
25 |
pub flags: ClientFlags, |
13419 | 26 |
pub teams_in_game: u8, |
13423 | 27 |
pub team_indices: Vec<u8>, |
14478 | 28 |
pub clan: Option<u8>, |
12128 | 29 |
} |
30 |
||
15096 | 31 |
impl HwClient { |
32 |
pub fn new(id: ClientId, protocol_number: u16, nick: String) -> HwClient { |
|
33 |
HwClient { |
|
13119
1e39b8749072
separated the server logic from all the async io mess.
alfadur
parents:
12853
diff
changeset
|
34 |
id, |
14714 | 35 |
nick, |
36 |
protocol_number, |
|
12146
8d8fb85bc09c
SendAllButMe action, list all clients in lobby in LobbyJoined message to newcomers
unc0rr
parents:
12144
diff
changeset
|
37 |
room_id: None, |
13529 | 38 |
flags: ClientFlags::DEFAULT, |
13419 | 39 |
teams_in_game: 0, |
13423 | 40 |
team_indices: Vec::new(), |
13419 | 41 |
clan: None, |
12128 | 42 |
} |
43 |
} |
|
13486 | 44 |
|
14478 | 45 |
fn contains(&self, mask: ClientFlags) -> bool { |
13493
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
46 |
self.flags.contains(mask) |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
47 |
} |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
48 |
|
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
49 |
fn set(&mut self, mask: ClientFlags, value: bool) { |
282e5e54386f
Something down in the food chain already uses bitflags, so might as well switch to them
alfadur
parents:
13486
diff
changeset
|
50 |
self.flags.set(mask, value); |
13486 | 51 |
} |
52 |
||
14478 | 53 |
pub fn is_admin(&self) -> bool { |
54 |
self.contains(ClientFlags::IS_ADMIN) |
|
55 |
} |
|
56 |
pub fn is_master(&self) -> bool { |
|
57 |
self.contains(ClientFlags::IS_MASTER) |
|
58 |
} |
|
59 |
pub fn is_ready(&self) -> bool { |
|
60 |
self.contains(ClientFlags::IS_READY) |
|
61 |
} |
|
62 |
pub fn is_in_game(&self) -> bool { |
|
63 |
self.contains(ClientFlags::IS_IN_GAME) |
|
64 |
} |
|
14800
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
65 |
pub fn is_contributor(&self) -> bool { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
66 |
self.contains(ClientFlags::IS_CONTRIBUTOR) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
67 |
} |
14807
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
68 |
pub fn has_super_power(&self) -> bool { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
69 |
self.contains(ClientFlags::HAS_SUPER_POWER) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
70 |
} |
14812 | 71 |
pub fn is_registered(&self) -> bool { |
72 |
self.contains(ClientFlags::IS_REGISTERED) |
|
73 |
} |
|
13486 | 74 |
|
14478 | 75 |
pub fn set_is_admin(&mut self, value: bool) { |
76 |
self.set(ClientFlags::IS_ADMIN, value) |
|
77 |
} |
|
78 |
pub fn set_is_master(&mut self, value: bool) { |
|
79 |
self.set(ClientFlags::IS_MASTER, value) |
|
80 |
} |
|
81 |
pub fn set_is_ready(&mut self, value: bool) { |
|
82 |
self.set(ClientFlags::IS_READY, value) |
|
83 |
} |
|
84 |
pub fn set_is_in_game(&mut self, value: bool) { |
|
85 |
self.set(ClientFlags::IS_IN_GAME, value) |
|
86 |
} |
|
14800
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
87 |
pub fn set_is_contributor(&mut self, value: bool) { |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
88 |
self.set(ClientFlags::IS_CONTRIBUTOR, value) |
f43ab2bd76ae
add a thread for internal server IO and implement account checking with it
alfadur
parents:
14714
diff
changeset
|
89 |
} |
14807
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
90 |
pub fn set_has_super_power(&mut self, value: bool) { |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
91 |
self.set(ClientFlags::HAS_SUPER_POWER, value) |
8ecdb5c6bb2a
implement info, registered only & super power messages
alfadur
parents:
14800
diff
changeset
|
92 |
} |
14812 | 93 |
pub fn set_is_registered(&mut self, value: bool) { |
94 |
self.set(ClientFlags::IS_REGISTERED, value) |
|
95 |
} |
|
14478 | 96 |
} |