mirror of
https://github.com/mat-1/azalea.git
synced 2025-08-02 06:16:04 +00:00
delete packet-macros
This commit is contained in:
parent
1286286e83
commit
ec03abfe69
3 changed files with 0 additions and 159 deletions
|
@ -11,7 +11,6 @@ async-trait = "0.1.51"
|
|||
byteorder = "^1.4.3"
|
||||
bytes = "^1.1.0"
|
||||
minecraft-chat = {path = "../minecraft-chat"}
|
||||
packet-macros = {path = "./packet-macros"}
|
||||
serde = {version = "1.0.130", features = ["serde_derive"]}
|
||||
serde_json = "^1.0.72"
|
||||
thiserror = "^1.0.30"
|
||||
|
|
|
@ -1,13 +0,0 @@
|
|||
[package]
|
||||
edition = "2021"
|
||||
name = "packet-macros"
|
||||
version = "0.1.0"
|
||||
|
||||
[lib]
|
||||
proc-macro = true
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
||||
casey = "^0.3.3"
|
||||
quote = "^1.0.10"
|
||||
syn = "^1.0.82"
|
|
@ -1,145 +0,0 @@
|
|||
use casey::{pascal, snake};
|
||||
extern crate proc_macro;
|
||||
|
||||
use proc_macro::TokenStream;
|
||||
use quote::quote;
|
||||
use syn::{
|
||||
self,
|
||||
parse::{Parse, ParseStream},
|
||||
parse_macro_input, DeriveInput, Signature,
|
||||
};
|
||||
|
||||
// #[derive(Clone, Debug)]
|
||||
// pub enum Packet {
|
||||
// // game
|
||||
|
||||
// // handshake
|
||||
// ClientIntentionPacket(handshake::client_intention_packet::ClientIntentionPacket),
|
||||
|
||||
// // login
|
||||
|
||||
// // status
|
||||
// ServerboundStatusRequestPacket(
|
||||
// status::serverbound_status_request_packet::ServerboundStatusRequestPacket,
|
||||
// ),
|
||||
// ClientboundStatusResponsePacket(
|
||||
// status::clientbound_status_response_packet::ClientboundStatusResponsePacket,
|
||||
// ),
|
||||
// }
|
||||
|
||||
// // TODO: do all this with macros so it's less repetitive
|
||||
// impl Packet {
|
||||
// fn get_inner_packet(&self) -> &dyn PacketTrait {
|
||||
// match self {
|
||||
// Packet::ClientIntentionPacket(packet) => packet,
|
||||
// Packet::ServerboundStatusRequestPacket(packet) => packet,
|
||||
// Packet::ClientboundStatusResponsePacket(packet) => packet,
|
||||
// }
|
||||
// }
|
||||
|
||||
// pub fn id(&self) -> u32 {
|
||||
// match self {
|
||||
// Packet::ClientIntentionPacket(_packet) => 0x00,
|
||||
// Packet::ServerboundStatusRequestPacket(_packet) => 0x00,
|
||||
// Packet::ClientboundStatusResponsePacket(_packet) => 0x00,
|
||||
// }
|
||||
// }
|
||||
|
||||
// /// Read a packet by its id, ConnectionProtocol, and flow
|
||||
// pub async fn read<T: tokio::io::AsyncRead + std::marker::Unpin + std::marker::Send>(
|
||||
// id: u32,
|
||||
// protocol: &ConnectionProtocol,
|
||||
// flow: &PacketFlow,
|
||||
// buf: &mut BufReader<T>,
|
||||
// ) -> Result<Packet, String> {
|
||||
// match protocol {
|
||||
// ConnectionProtocol::Handshake => match id {
|
||||
// 0x00 => Ok(
|
||||
// handshake::client_intention_packet::ClientIntentionPacket::read(buf).await?,
|
||||
// ),
|
||||
// _ => Err(format!("Unknown packet id: {}", id)),
|
||||
// },
|
||||
// ConnectionProtocol::Game => Err("Game protocol not implemented yet".to_string()),
|
||||
// ConnectionProtocol::Status => match flow {
|
||||
// PacketFlow::ServerToClient => match id {
|
||||
// 0x00 => Ok(
|
||||
// status::clientbound_status_response_packet::ClientboundStatusResponsePacket
|
||||
// ::read(buf)
|
||||
// .await?,
|
||||
// ),
|
||||
// _ => Err(format!("Unknown packet id: {}", id)),
|
||||
// },
|
||||
// PacketFlow::ClientToServer => match id {
|
||||
// 0x00 => Ok(
|
||||
// status::serverbound_status_request_packet::ServerboundStatusRequestPacket
|
||||
// ::read(buf)
|
||||
// .await?,
|
||||
// ),
|
||||
// _ => Err(format!("Unknown packet id: {}", id)),
|
||||
// },
|
||||
// },
|
||||
// ConnectionProtocol::Login => Err("Login protocol not implemented yet".to_string()),
|
||||
// }
|
||||
// }
|
||||
|
||||
// pub fn write(&self, buf: &mut Vec<u8>) {
|
||||
// self.get_inner_packet().write(buf);
|
||||
// }
|
||||
// }
|
||||
|
||||
struct RegisterPacket {
|
||||
name: syn::Ident,
|
||||
connection_protocol: syn::Ident,
|
||||
flow: syn::Ident,
|
||||
}
|
||||
|
||||
struct RegisterPackets {
|
||||
packets: Vec<RegisterPacket>,
|
||||
}
|
||||
|
||||
impl Parse for RegisterPackets {
|
||||
fn parse(input: ParseStream) -> syn::Result<Self> {
|
||||
let packets = vec![];
|
||||
loop {
|
||||
let name: syn::Ident = input.parse()?;
|
||||
|
||||
input.parse::<syn::Token![=>]>()?;
|
||||
|
||||
let connection_protocol: syn::Ident = input.parse()?;
|
||||
input.parse::<syn::Token![,]>()?;
|
||||
let flow: syn::Ident = input.parse()?;
|
||||
|
||||
input.parse::<syn::Token![;]>()?;
|
||||
|
||||
packets.push(RegisterPacket {
|
||||
name,
|
||||
connection_protocol,
|
||||
flow,
|
||||
});
|
||||
|
||||
if input.is_empty() {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
Ok(RegisterPackets { packets })
|
||||
}
|
||||
}
|
||||
|
||||
#[proc_macro]
|
||||
pub fn register_packets(input: TokenStream) -> TokenStream {
|
||||
let RegisterPackets { packets } = syn::parse_macro_input!(input as RegisterPackets);
|
||||
|
||||
// ClientIntentionPacket(handshake::client_intention_packet::ClientIntentionPacket),
|
||||
let gen = quote! {
|
||||
// #[derive(Clone, Debug)]
|
||||
// pub enum Packet {
|
||||
// // ClientIntentionPacket(handshake::client_intention_packet::ClientIntentionPacket),
|
||||
// // ClientboundStatusResponsePacket(
|
||||
// // status::clientbound_status_response_packet::ClientboundStatusResponsePacket,
|
||||
// // ),
|
||||
|
||||
// }
|
||||
};
|
||||
gen.into()
|
||||
}
|
Loading…
Add table
Reference in a new issue