convert macros into functions
This commit is contained in:
		
							parent
							
								
									22278e04e6
								
							
						
					
					
						commit
						9ff866c489
					
				| @ -1,7 +1,8 @@ | |||||||
| use chrono::{DateTime, Utc}; | use chrono::{DateTime, Utc}; | ||||||
| 
 | 
 | ||||||
| use psopacket::{pso_packet, PSOPacketData}; | use psopacket::{pso_packet, PSOPacketData}; | ||||||
| use crate::{PSOPacket, PacketParseError, PSOPacketData, utf8_to_utf16_array}; | use crate::{PSOPacket, PacketParseError, PSOPacketData}; | ||||||
|  | use crate::util::utf8_to_utf16_array; | ||||||
| 
 | 
 | ||||||
| use crate::character::character::SelectScreenCharacter; | use crate::character::character::SelectScreenCharacter; | ||||||
| 
 | 
 | ||||||
| @ -492,7 +493,7 @@ impl ShipList { | |||||||
|                 menu: ships.get(0).map(|s| s.menu).unwrap_or(0), |                 menu: ships.get(0).map(|s| s.menu).unwrap_or(0), | ||||||
|                 item: 0, |                 item: 0, | ||||||
|                 flags: 0, |                 flags: 0, | ||||||
|                 name: utf8_to_utf16_array!("Ship", 0x11), |                 name: utf8_to_utf16_array("Ship"), | ||||||
|             }, |             }, | ||||||
|             ships: ships, |             ships: ships, | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| use psopacket::{pso_packet, PSOPacketData}; | use psopacket::{pso_packet, PSOPacketData}; | ||||||
| use crate::{PSOPacket, PacketParseError, PSOPacketData}; | use crate::{PSOPacket, PacketParseError, PSOPacketData}; | ||||||
| use crate::utf8_to_utf16_array; | use crate::util::utf8_to_utf16_array; | ||||||
| use crate::packet::messages::GameMessage; | use crate::packet::messages::GameMessage; | ||||||
| //use character::character::FullCharacter;
 | //use character::character::FullCharacter;
 | ||||||
| use crate::character::character as character; | use crate::character::character as character; | ||||||
| @ -82,13 +82,13 @@ impl ShipBlockList { | |||||||
|                 menu: BLOCK_MENU_ID, |                 menu: BLOCK_MENU_ID, | ||||||
|                 item: 0, |                 item: 0, | ||||||
|                 flags: 0, |                 flags: 0, | ||||||
|                 name: utf8_to_utf16_array!(shipname, 0x11) |                 name: utf8_to_utf16_array(shipname) | ||||||
|             }, |             }, | ||||||
|             blocks: (0..num_blocks).map(|i| BlockEntry { |             blocks: (0..num_blocks).map(|i| BlockEntry { | ||||||
|                 menu: BLOCK_MENU_ID, |                 menu: BLOCK_MENU_ID, | ||||||
|                 item: i as u32 + 1, |                 item: i as u32 + 1, | ||||||
|                 flags: 0, |                 flags: 0, | ||||||
|                 name: utf8_to_utf16_array!(format!("Block {}", i+1), 0x11) |                 name: utf8_to_utf16_array(format!("Block {}", i+1)) | ||||||
|             }).collect() |             }).collect() | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
							
								
								
									
										46
									
								
								src/util.rs
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								src/util.rs
									
									
									
									
									
								
							| @ -16,31 +16,19 @@ pub fn array_to_utf16(array: &[u8]) -> String { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | pub fn utf8_to_array<const N: usize>(s: impl Into<String>) -> [u8; N] { | ||||||
| // TODO: const fn version of this! (helpful with tests)
 |     let mut array = [0u8; N]; | ||||||
| #[macro_export] |     let s = s.into(); | ||||||
| macro_rules! utf8_to_array { |     let bytes = s.as_bytes(); | ||||||
|     ($s: expr, $size: expr) => { |     array[..bytes.len()].clone_from_slice(&bytes); | ||||||
|         { |     array | ||||||
|             let mut array = [0u8; $size]; |  | ||||||
|             let bytes = $s.as_bytes(); |  | ||||||
|             array[..bytes.len()].clone_from_slice(&bytes); |  | ||||||
|             array |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[macro_export] | pub fn utf8_to_utf16_array<const N: usize>(s: impl Into<String>) -> [u16; N] { | ||||||
| macro_rules! utf8_to_utf16_array { |     let mut array = [0u16; N]; | ||||||
|     ($s: expr, $size: expr) => { |     let bytes = s.into().encode_utf16().collect::<Vec<_>>(); | ||||||
|         { |     array[..bytes.len()].clone_from_slice(&bytes); | ||||||
|             let mut array = [0u16; $size]; |     array | ||||||
|             //let bytes = $s.as_bytes();
 |  | ||||||
|             let bytes = $s.encode_utf16().collect::<Vec<_>>(); |  | ||||||
|             array[..bytes.len()].clone_from_slice(&bytes); |  | ||||||
|             array |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub fn vec_to_array<T: Default + Copy, const N: usize>(vec: Vec<T>) -> [T; N] { | pub fn vec_to_array<T: Default + Copy, const N: usize>(vec: Vec<T>) -> [T; N] { | ||||||
| @ -53,10 +41,12 @@ pub fn vec_to_array<T: Default + Copy, const N: usize>(vec: Vec<T>) -> [T; N] { | |||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod test { | mod test { | ||||||
|  |     use super::*; | ||||||
|  | 
 | ||||||
|     #[test] |     #[test] | ||||||
|     fn test_utf8_to_array() { |     fn test_utf8_to_array() { | ||||||
|         let s = "asdf".to_owned(); |         let s = "asdf".to_owned(); | ||||||
|         let a = utf8_to_array!(s, 8); |         let a = utf8_to_array(s); | ||||||
| 
 | 
 | ||||||
|         let mut e = [0u8; 8]; |         let mut e = [0u8; 8]; | ||||||
|         e[..4].clone_from_slice(b"asdf"); |         e[..4].clone_from_slice(b"asdf"); | ||||||
| @ -64,14 +54,14 @@ mod test { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[test] |     #[test] | ||||||
|     fn utf8_to_utf16_array() { |     fn test_utf8_to_utf16_array() { | ||||||
|         let utf16 = utf8_to_utf16_array!("asdf", 16); |         let utf16 = utf8_to_utf16_array("asdf"); | ||||||
|         assert!(utf16 == [97, 115, 100, 102, 0,0,0,0,0,0,0,0,0,0,0,0]) |         assert!(utf16 == [97, 115, 100, 102, 0,0,0,0,0,0,0,0,0,0,0,0]) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[test] |     #[test] | ||||||
|     fn utf8_to_utf16_array_unicode() { |     fn test_utf8_to_utf16_array_unicode() { | ||||||
|         let utf16 = utf8_to_utf16_array!("あいうえお", 16); |         let utf16 = utf8_to_utf16_array("あいうえお"); | ||||||
|         assert!(utf16 == [0x3042 , 0x3044, 0x3046, 0x3048, 0x304A, 0,0,0,0,0,0,0,0,0,0,0]) |         assert!(utf16 == [0x3042 , 0x3044, 0x3046, 0x3048, 0x304A, 0,0,0,0,0,0,0,0,0,0,0]) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user