handle String objects in pso_packet
This commit is contained in:
parent
c6ad5f4be6
commit
47a07a63ae
@ -100,10 +100,26 @@ pub fn pso_packet(attr: TokenStream, item: TokenStream) -> TokenStream {
|
||||
dbg_write_vars.push(quote! {
|
||||
write!(f, " {}: {:?}\n", #ident_str, self.#ident).unwrap();
|
||||
});
|
||||
as_bytes.push(quote! {
|
||||
buf.extend_from_slice(&self.#ident.to_le_bytes());
|
||||
});
|
||||
let ty = path.path.segments[0].ident.to_string();
|
||||
|
||||
// as_bytes
|
||||
match ty.as_str() {
|
||||
"String" => {
|
||||
as_bytes.push(quote! {
|
||||
for c in self.#ident.as_str().encode_utf16() {
|
||||
buf.extend_from_slice(&c.to_le_bytes());
|
||||
}
|
||||
//buf.extend_from_slice(&self.#ident.as_str().encode_utf16());
|
||||
});
|
||||
}
|
||||
_ => {
|
||||
as_bytes.push(quote! {
|
||||
buf.extend_from_slice(&self.#ident.to_le_bytes());
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// from_bytes
|
||||
match ty.as_str() {
|
||||
"u8" | "u8_str" => {
|
||||
from_bytes.push(quote! {
|
||||
@ -153,6 +169,19 @@ pub fn pso_packet(attr: TokenStream, item: TokenStream) -> TokenStream {
|
||||
},
|
||||
});
|
||||
},
|
||||
"String" => {
|
||||
from_bytes.push(quote! {
|
||||
#ident: {
|
||||
let mut s = String::new();
|
||||
if let Ok(len) = cur.read_to_string(&mut s) {
|
||||
}
|
||||
else {
|
||||
return Err(PacketParseError::NotEnoughBytes);
|
||||
};
|
||||
s
|
||||
},
|
||||
});
|
||||
},
|
||||
_ => {
|
||||
return syn::Error::new(path.path.segments[0].ident.span(), "type not supported")
|
||||
.to_compile_error().into();
|
||||
|
Loading…
x
Reference in New Issue
Block a user