aboutsummaryrefslogtreecommitdiff
path: root/src/bitboard.rs
diff options
context:
space:
mode:
authoreug-vs <eugene@eug-vs.xyz>2023-01-21 00:47:57 +0300
committereug-vs <eugene@eug-vs.xyz>2023-01-21 00:49:16 +0300
commit46cbe2683efbbdef1e445722617ecf9905d92652 (patch)
tree6407acf3a34db34bd48185d83dd189c4eb183988 /src/bitboard.rs
parent0a890b42e8b701feed27faee4b0caf601f5bb258 (diff)
downloadchessnost-46cbe2683efbbdef1e445722617ecf9905d92652.tar.gz
refactor: do not pass u64 by reference
This is pointless since size of a pointer is also 64 bit on x64 systems, so we are not saving any memory at this point
Diffstat (limited to 'src/bitboard.rs')
-rw-r--r--src/bitboard.rs33
1 files changed, 16 insertions, 17 deletions
diff --git a/src/bitboard.rs b/src/bitboard.rs
index 6aba264..0b62f87 100644
--- a/src/bitboard.rs
+++ b/src/bitboard.rs
@@ -2,7 +2,7 @@ pub type Bitboard = u64;
/// Print bitboard on screen in the same way squares appear in memory
/// (i.e the board is actually flipped along X)
-pub fn print(bb: &Bitboard) {
+pub fn print(bb: Bitboard) {
for index in 0..64 {
print!("{}", if bb >> index & 1 == 1 { "1" } else { "." });
if (index + 1) % 8 == 0 {
@@ -13,15 +13,15 @@ pub fn print(bb: &Bitboard) {
}
/// Return bitboard cardinality, aka number of elements in the set
-pub fn pop_count(bb: &Bitboard) -> u8 {
- if bb == &0u64 {
+pub fn pop_count(bb: Bitboard) -> u8 {
+ if bb == 0 {
return 0;
}
- return pop_count(&(bb >> 1)) + (bb & 1) as u8;
+ return pop_count(bb >> 1) + (bb & 1) as u8;
}
/// Return Bitboard with only Least Single Bit
-pub fn ls1b(bb: &Bitboard) -> u64 {
+pub fn ls1b(bb: Bitboard) -> u64 {
bb & !(bb - 1)
}
@@ -29,40 +29,39 @@ pub fn ls1b(bb: &Bitboard) -> u64 {
///
/// WARNING: Only works for SINGLE Bitboards
/// Useful for calculating bit-index of LS1B
-pub fn bitscan(bb: &Bitboard) -> u8 {
+pub fn bitscan(bb: Bitboard) -> u8 {
debug_assert!(pop_count(bb) == 1, "Bitscan only works for SINGLE Bitboards!");
- pop_count(&(bb - 1))
+ pop_count(bb - 1)
}
-
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_pop_count() {
- assert_eq!(pop_count(&127), 7);
+ assert_eq!(pop_count(127), 7);
}
#[test]
fn test_ls1b() {
- assert_eq!(ls1b(&38), 2);
- assert_eq!(ls1b(&16), 16);
- assert_eq!(ls1b(&20), 4);
+ assert_eq!(ls1b(38), 2);
+ assert_eq!(ls1b(16), 16);
+ assert_eq!(ls1b(20), 4);
}
#[test]
fn test_bitscan() {
- assert_eq!(bitscan(&4), 2);
- assert_eq!(bitscan(&16), 4);
- assert_eq!(bitscan(&64), 6);
- assert_eq!(bitscan(&128), 7);
+ assert_eq!(bitscan(4), 2);
+ assert_eq!(bitscan(16), 4);
+ assert_eq!(bitscan(64), 6);
+ assert_eq!(bitscan(128), 7);
}
#[test]
#[should_panic(expected = "Bitscan only works for SINGLE Bitboards!")]
fn test_bitscan_with_non_single_bb() {
- bitscan(&5);
+ bitscan(5);
}
}