|
@@ -1,6 +1,6 @@
|
|
mod expand;
|
|
mod expand;
|
|
|
|
|
|
-use expand::{Args, Map, Probe, ProbeKind, SkMsg, SockOps, Xdp};
|
|
|
|
|
|
+use expand::{Args, Map, Probe, ProbeKind, SchedClassifier, SkMsg, SockOps, Xdp};
|
|
use proc_macro::TokenStream;
|
|
use proc_macro::TokenStream;
|
|
use syn::{parse_macro_input, ItemFn, ItemStatic};
|
|
use syn::{parse_macro_input, ItemFn, ItemStatic};
|
|
|
|
|
|
@@ -68,6 +68,17 @@ pub fn xdp(attrs: TokenStream, item: TokenStream) -> TokenStream {
|
|
.into()
|
|
.into()
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+#[proc_macro_attribute]
|
|
|
|
+pub fn classifier(attrs: TokenStream, item: TokenStream) -> TokenStream {
|
|
|
|
+ let args = parse_macro_input!(attrs as Args);
|
|
|
|
+ let item = parse_macro_input!(item as ItemFn);
|
|
|
|
+
|
|
|
|
+ SchedClassifier::from_syn(args, item)
|
|
|
|
+ .and_then(|u| u.expand())
|
|
|
|
+ .unwrap_or_else(|err| err.to_compile_error())
|
|
|
|
+ .into()
|
|
|
|
+}
|
|
|
|
+
|
|
fn probe(kind: ProbeKind, attrs: TokenStream, item: TokenStream) -> TokenStream {
|
|
fn probe(kind: ProbeKind, attrs: TokenStream, item: TokenStream) -> TokenStream {
|
|
let args = parse_macro_input!(attrs as Args);
|
|
let args = parse_macro_input!(attrs as Args);
|
|
let item = parse_macro_input!(item as ItemFn);
|
|
let item = parse_macro_input!(item as ItemFn);
|