summaryrefslogtreecommitdiffstats
path: root/third_party/rust/unic-langid-macros-impl/src/lib.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /third_party/rust/unic-langid-macros-impl/src/lib.rs
parentInitial commit. (diff)
downloadfirefox-esr-upstream.tar.xz
firefox-esr-upstream.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--third_party/rust/unic-langid-macros-impl/src/lib.rs108
1 files changed, 108 insertions, 0 deletions
diff --git a/third_party/rust/unic-langid-macros-impl/src/lib.rs b/third_party/rust/unic-langid-macros-impl/src/lib.rs
new file mode 100644
index 0000000000..ee27a51e81
--- /dev/null
+++ b/third_party/rust/unic-langid-macros-impl/src/lib.rs
@@ -0,0 +1,108 @@
+extern crate proc_macro;
+
+use proc_macro::TokenStream;
+
+use proc_macro_hack::proc_macro_hack;
+use quote::quote;
+use syn::{parse_macro_input, LitStr};
+
+use unic_langid_impl::{subtags, LanguageIdentifier};
+
+#[proc_macro_hack]
+pub fn lang(input: TokenStream) -> TokenStream {
+ let id = parse_macro_input!(input as LitStr);
+ let parsed: subtags::Language = id.value().parse().expect("Malformed Language Subtag");
+
+ let lang: Option<u64> = parsed.into();
+ let lang = if let Some(lang) = lang {
+ quote!(unsafe { $crate::subtags::Language::from_raw_unchecked(#lang) })
+ } else {
+ quote!(None)
+ };
+
+ TokenStream::from(quote! {
+ #lang
+ })
+}
+
+#[proc_macro_hack]
+pub fn script(input: TokenStream) -> TokenStream {
+ let id = parse_macro_input!(input as LitStr);
+ let parsed: subtags::Script = id.value().parse().expect("Malformed Script Subtag");
+
+ let script: u32 = parsed.into();
+
+ TokenStream::from(quote! {
+ unsafe { $crate::subtags::Script::from_raw_unchecked(#script) }
+ })
+}
+
+#[proc_macro_hack]
+pub fn region(input: TokenStream) -> TokenStream {
+ let id = parse_macro_input!(input as LitStr);
+ let parsed: subtags::Region = id.value().parse().expect("Malformed Region Subtag");
+
+ let region: u32 = parsed.into();
+
+ TokenStream::from(quote! {
+ unsafe { $crate::subtags::Region::from_raw_unchecked(#region) }
+ })
+}
+
+#[proc_macro_hack]
+pub fn variant_fn(input: TokenStream) -> TokenStream {
+ let id = parse_macro_input!(input as LitStr);
+ let parsed: subtags::Variant = id.value().parse().expect("Malformed Variant Subtag");
+
+ let variant: u64 = parsed.into();
+
+ TokenStream::from(quote! {
+ unsafe { $crate::subtags::Variant::from_raw_unchecked(#variant) }
+ })
+}
+
+#[proc_macro_hack]
+pub fn langid(input: TokenStream) -> TokenStream {
+ let id = parse_macro_input!(input as LitStr);
+ let parsed: LanguageIdentifier = id.value().parse().expect("Malformed Language Identifier");
+
+ let (lang, script, region, variants) = parsed.into_parts();
+
+ let lang: Option<u64> = lang.into();
+ let lang = if let Some(lang) = lang {
+ quote!(unsafe { $crate::subtags::Language::from_raw_unchecked(#lang) })
+ } else {
+ quote!($crate::subtags::Language::default())
+ };
+
+ let script = if let Some(script) = script {
+ let script: u32 = script.into();
+ quote!(Some(unsafe { $crate::subtags::Script::from_raw_unchecked(#script) }))
+ } else {
+ quote!(None)
+ };
+
+ let region = if let Some(region) = region {
+ let region: u32 = region.into();
+ quote!(Some(unsafe { $crate::subtags::Region::from_raw_unchecked(#region) }))
+ } else {
+ quote!(None)
+ };
+
+ let variants = if !variants.is_empty() {
+ let v: Vec<_> = variants
+ .iter()
+ .map(|v| {
+ let variant: u64 = v.into();
+ quote!(unsafe { $crate::subtags::Variant::from_raw_unchecked(#variant) })
+ })
+ .collect();
+ quote!(Some(Box::new([#(#v,)*])))
+ } else {
+ quote!(None)
+ };
+
+ TokenStream::from(quote! {
+ unsafe { $crate::LanguageIdentifier::from_raw_parts_unchecked(#lang, #script, #region, #variants) }
+ })
+}