From 016aa6cbabe2305006aabea4245fb9c281c819ae Mon Sep 17 00:00:00 2001 From: Dietmar Maurer Date: Fri, 2 Nov 2018 09:44:18 +0100 Subject: [PATCH] define macro for propertymap --- src/json_schema.rs | 11 +++++++ src/main.rs | 82 +++++++++++++++++++++------------------------- 2 files changed, 49 insertions(+), 44 deletions(-) diff --git a/src/json_schema.rs b/src/json_schema.rs index da292c97..6456c72c 100644 --- a/src/json_schema.rs +++ b/src/json_schema.rs @@ -131,3 +131,14 @@ pub static PVE_VMID: Jss = Integer!{ description => "The (unique) ID of the VM.", minimum => Some(1) }; + +#[macro_export] +macro_rules! propertymap { + ($($name:ident => $e:expr),*) => { + PropertyMap { + entries: &[ + $( ( stringify!($name), $e), )* + ] + } + } +} diff --git a/src/main.rs b/src/main.rs index 08336b6a..b7918ee1 100644 --- a/src/main.rs +++ b/src/main.rs @@ -18,44 +18,40 @@ use hyper::{Method, Body, Request, Response, Server, StatusCode}; use hyper::rt::Future; use hyper::service::service_fn_ok; -static PARAMETERS1: PropertyMap = PropertyMap { - entries: &[ - ("force", Boolean!{ - description => "Test for boolean options." - }), - ("text1", ApiString!{ - description => "A simple text string.", - min_length => Some(10), - max_length => Some(30) - }), - ("count", Integer!{ - description => "A counter for everything.", - minimum => Some(0), - maximum => Some(10) - }), - ("myarray1", Array!{ - description => "Test Array of simple integers.", - items => &PVE_VMID - }), - ("myarray2", Jss::Array(JssArray { - description: "Test Array of simple integers.", - optional: Some(false), - items: &Object!{description => "Empty Object."}, - })), - ("myobject", Object!{ - description => "TEST Object.", - properties => &PropertyMap { - entries: &[ - ("vmid", Jss::Reference { reference: &PVE_VMID}), - ("loop", Integer!{ - description => "Totally useless thing.", - optional => Some(false) - }) - ] +static PARAMETERS1: PropertyMap = propertymap!{ + force => Boolean!{ + description => "Test for boolean options." + }, + text1 => ApiString!{ + description => "A simple text string.", + min_length => Some(10), + max_length => Some(30) + }, + count => Integer!{ + description => "A counter for everything.", + minimum => Some(0), + maximum => Some(10) + }, + myarray1 => Array!{ + description => "Test Array of simple integers.", + items => &PVE_VMID + }, + myarray2 => Jss::Array(JssArray { + description: "Test Array of simple integers.", + optional: Some(false), + items: &Object!{description => "Empty Object."}, + }), + myobject => Object!{ + description => "TEST Object.", + properties => &propertymap!{ + vmid => Jss::Reference { reference: &PVE_VMID}, + loop => Integer!{ + description => "Totally useless thing.", + optional => Some(false) } - }), - ("emptyobject", Object!{description => "Empty Object."}), - ] + } + }, + emptyobject => Object!{description => "Empty Object."} }; @@ -87,13 +83,11 @@ fn test_api_handler(param: Value) -> Result { static TEST_API_METHOD: ApiMethod = ApiMethod { description: "This is a simple test.", - properties: &PropertyMap { - entries: &[ - ("force", Boolean!{ - optional => Some(true), - description => "Test for boolean options." - }) - ] + properties: &propertymap!{ + force => Boolean!{ + optional => Some(true), + description => "Test for boolean options." + } }, returns: &Jss::Null, handler: test_api_handler,