Add in proc macro decoder generation

This commit is contained in:
vagola
2020-01-04 11:12:05 +03:00
parent 61fff6fcf7
commit 73528233eb
3 changed files with 64 additions and 20 deletions

View File

@@ -480,7 +480,7 @@ macro_rules! impl_json_encoder_decoder (
);
mod var_int {
use crate::{DecodeError, EncodeError, Encoder};
use crate::{DecodeError, EncodeError};
use mc_varint::{VarIntRead, VarIntWrite};
use std::io::{Read, Write};
@@ -496,7 +496,7 @@ mod var_int {
}
mod var_long {
use crate::{DecodeError, EncodeError, Encoder};
use crate::{DecodeError, EncodeError};
use mc_varint::{VarIntRead, VarIntWrite};
use std::io::{Read, Write};
@@ -512,7 +512,7 @@ mod var_long {
}
mod rest {
use crate::{DecodeError, Decoder, EncodeError, Encoder};
use crate::{DecodeError, EncodeError};
use std::io::{Read, Write};
pub fn encode<W: Write>(value: &[u8], writer: &mut W) -> Result<(), EncodeError> {
@@ -531,8 +531,7 @@ mod rest {
mod uuid_hyp_str {
use crate::{
DecodeError, Decoder, DecoderReadExt, EncodeError, Encoder, EncoderWriteExt,
HYPHENATED_UUID_LENGTH,
DecodeError, DecoderReadExt, EncodeError, EncoderWriteExt, HYPHENATED_UUID_LENGTH,
};
use std::io::{Read, Write};
use uuid::Uuid;

View File

@@ -115,7 +115,7 @@ impl LoginStart {
}
}
#[derive(Packet, Debug)]
#[derive(Debug)]
pub struct EncryptionResponse {
pub shared_secret: Vec<u8>,
pub verify_token: Vec<u8>,
@@ -132,6 +132,28 @@ impl EncryptionResponse {
}
}
impl crate::Encoder for EncryptionResponse {
fn encode<W: std::io::Write>(&self, writer: &mut W) -> Result<(), crate::EncodeError> {
crate::Encoder::encode(&self.shared_secret, writer)?;
crate::Encoder::encode(&self.verify_token, writer)?;
Ok(())
}
}
impl crate::Decoder for EncryptionResponse {
type Output = Self;
fn decode<R: std::io::Read>(reader: &mut R) -> Result<Self::Output, crate::DecodeError> {
let shared_secret = <Vec<u8> as crate::Decoder>::decode(reader)?;
let verify_token = <Vec<u8> as crate::Decoder>::decode(reader)?;
Ok(EncryptionResponse {
shared_secret,
verify_token,
})
}
}
#[derive(Packet, Debug)]
pub struct LoginPluginResponse {
#[packet(with = "var_int")]