macros: Move additional utility function into util module
This commit is contained in:
parent
bb26f159e3
commit
0faa00ca95
@ -8,6 +8,7 @@ use super::{
|
|||||||
event_parse::{EventEnumDecl, EventEnumEntry, EventKind, EventKindVariation},
|
event_parse::{EventEnumDecl, EventEnumEntry, EventKind, EventKindVariation},
|
||||||
util::{has_prev_content_field, EVENT_FIELDS},
|
util::{has_prev_content_field, EVENT_FIELDS},
|
||||||
};
|
};
|
||||||
|
use crate::util::m_prefix_name_to_type_name;
|
||||||
|
|
||||||
/// Create a content enum from `EventEnumInput`.
|
/// Create a content enum from `EventEnumInput`.
|
||||||
pub fn expand_event_enums(input: &EventEnumDecl) -> syn::Result<TokenStream> {
|
pub fn expand_event_enums(input: &EventEnumDecl) -> syn::Result<TokenStream> {
|
||||||
@ -574,27 +575,6 @@ fn to_event_content_path(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Splits the given `event_type` string on `.` and `_` removing the `m.room.` then
|
|
||||||
/// camel casing to give the `Event` struct name.
|
|
||||||
fn to_camel_case(name: &LitStr) -> syn::Result<Ident> {
|
|
||||||
let span = name.span();
|
|
||||||
let name = name.value();
|
|
||||||
|
|
||||||
if &name[..2] != "m." {
|
|
||||||
return Err(syn::Error::new(
|
|
||||||
span,
|
|
||||||
format!("well-known matrix events have to start with `m.` found `{}`", name),
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
let s: String = name[2..]
|
|
||||||
.split(&['.', '_'] as &[char])
|
|
||||||
.map(|s| s.chars().next().unwrap().to_uppercase().to_string() + &s[1..])
|
|
||||||
.collect();
|
|
||||||
|
|
||||||
Ok(Ident::new(&s, span))
|
|
||||||
}
|
|
||||||
|
|
||||||
fn field_return_type(
|
fn field_return_type(
|
||||||
name: &str,
|
name: &str,
|
||||||
var: EventKindVariation,
|
var: EventKindVariation,
|
||||||
@ -657,7 +637,7 @@ impl EventEnumVariant {
|
|||||||
impl EventEnumEntry {
|
impl EventEnumEntry {
|
||||||
pub(crate) fn to_variant(&self) -> syn::Result<EventEnumVariant> {
|
pub(crate) fn to_variant(&self) -> syn::Result<EventEnumVariant> {
|
||||||
let attrs = self.attrs.clone();
|
let attrs = self.attrs.clone();
|
||||||
let ident = to_camel_case(&self.ev_type)?;
|
let ident = m_prefix_name_to_type_name(&self.ev_type)?;
|
||||||
Ok(EventEnumVariant { attrs, ident })
|
Ok(EventEnumVariant { attrs, ident })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use proc_macro2::TokenStream;
|
use proc_macro2::TokenStream;
|
||||||
use proc_macro_crate::{crate_name, FoundCrate};
|
use proc_macro_crate::{crate_name, FoundCrate};
|
||||||
use quote::{format_ident, quote};
|
use quote::{format_ident, quote};
|
||||||
use syn::Ident;
|
use syn::{Ident, LitStr};
|
||||||
|
|
||||||
pub(crate) fn import_ruma_common() -> TokenStream {
|
pub(crate) fn import_ruma_common() -> TokenStream {
|
||||||
if let Ok(FoundCrate::Name(name)) = crate_name("ruma-common") {
|
if let Ok(FoundCrate::Name(name)) = crate_name("ruma-common") {
|
||||||
@ -32,3 +32,24 @@ pub(crate) fn to_camel_case(name: &Ident) -> Ident {
|
|||||||
.collect();
|
.collect();
|
||||||
Ident::new(&s, span)
|
Ident::new(&s, span)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Splits the given string on `.` and `_` removing the `m.` then camel casing to give a Rust type
|
||||||
|
/// name.
|
||||||
|
pub(crate) fn m_prefix_name_to_type_name(name: &LitStr) -> syn::Result<Ident> {
|
||||||
|
let span = name.span();
|
||||||
|
let name = name.value();
|
||||||
|
|
||||||
|
if &name[..2] != "m." {
|
||||||
|
return Err(syn::Error::new(
|
||||||
|
span,
|
||||||
|
format!("well-known matrix events have to start with `m.` found `{}`", name),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
let s: String = name[2..]
|
||||||
|
.split(&['.', '_'] as &[char])
|
||||||
|
.map(|s| s.chars().next().unwrap().to_uppercase().to_string() + &s[1..])
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
Ok(Ident::new(&s, span))
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user