David Tolnay | 86eca75 | 2016-09-04 11:26:41 -0700 | [diff] [blame] | 1 | #[cfg(feature = "parsing")] |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 2 | #[macro_use] |
| 3 | extern crate nom; |
| 4 | |
David Tolnay | 87d0b44 | 2016-09-04 11:52:12 -0700 | [diff] [blame] | 5 | #[cfg(feature = "printing")] |
| 6 | extern crate quote; |
| 7 | |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 8 | #[macro_use] |
David Tolnay | 6b7aaf0 | 2016-09-04 10:39:25 -0700 | [diff] [blame] | 9 | mod do_parse; |
| 10 | |
| 11 | #[macro_use] |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 12 | mod helper; |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 13 | |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 14 | mod attr; |
| 15 | pub use attr::{ |
| 16 | Attribute, |
| 17 | MetaItem, |
| 18 | }; |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 19 | |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 20 | mod generics; |
| 21 | pub use generics::{ |
| 22 | Generics, |
| 23 | Lifetime, |
| 24 | LifetimeDef, |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 25 | TraitBoundModifier, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 26 | TyParam, |
| 27 | TyParamBound, |
| 28 | WhereBoundPredicate, |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 29 | WhereClause, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 30 | WherePredicate, |
| 31 | WhereRegionPredicate, |
| 32 | }; |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 33 | |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 34 | mod ident; |
| 35 | pub use ident::{ |
| 36 | Ident, |
| 37 | }; |
| 38 | |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 39 | mod item; |
| 40 | pub use item::{ |
| 41 | Body, |
| 42 | Field, |
| 43 | Item, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 44 | Variant, |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 45 | VariantData, |
| 46 | Visibility, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 47 | }; |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 48 | |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 49 | mod ty; |
| 50 | pub use ty::{ |
| 51 | AngleBracketedParameterData, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 52 | BareFnTy, |
David Tolnay | 66daf74 | 2016-09-07 08:21:49 -0700 | [diff] [blame] | 53 | FnArg, |
David Tolnay | b79ee96 | 2016-09-04 09:39:20 -0700 | [diff] [blame] | 54 | FnDecl, |
| 55 | FunctionRetTy, |
| 56 | MutTy, |
| 57 | Mutability, |
| 58 | ParenthesizedParameterData, |
| 59 | Path, |
| 60 | PathParameters, |
| 61 | PathSegment, |
| 62 | PolyTraitRef, |
| 63 | QSelf, |
| 64 | Ty, |
| 65 | TypeBinding, |
| 66 | }; |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 67 | |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 68 | #[cfg(feature = "aster")] |
| 69 | pub mod aster; |
David Tolnay | 7ebb9fb | 2016-09-03 12:07:47 -0700 | [diff] [blame] | 70 | |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 71 | #[cfg(feature = "visit")] |
| 72 | pub mod visit; |
| 73 | |
| 74 | #[cfg(feature = "parsing")] |
| 75 | pub use parsing::*; |
| 76 | |
| 77 | #[cfg(feature = "parsing")] |
| 78 | mod parsing { |
| 79 | use super::*; |
| 80 | use {generics, item, ty}; |
| 81 | use nom; |
| 82 | |
| 83 | pub fn parse_item(input: &str) -> Result<Item, String> { |
| 84 | unwrap("item", item::parsing::item(input)) |
| 85 | } |
| 86 | |
| 87 | pub fn parse_path(input: &str) -> Result<Path, String> { |
| 88 | unwrap("path", ty::parsing::path(input)) |
| 89 | } |
| 90 | |
| 91 | pub fn parse_where_clause(input: &str) -> Result<WhereClause, String> { |
| 92 | unwrap("where clause", generics::parsing::where_clause(input)) |
| 93 | } |
| 94 | |
| 95 | fn unwrap<T>(name: &'static str, ires: nom::IResult<&str, T>) -> Result<T, String> { |
| 96 | return match ires { |
| 97 | nom::IResult::Done(rest, t) => { |
| 98 | if rest.is_empty() { |
| 99 | Ok(t) |
| 100 | } else { |
| 101 | Err(format!("remaining tokens after {}: {:?}", name, rest)) |
David Tolnay | c94c38a | 2016-09-05 17:02:03 -0700 | [diff] [blame] | 102 | } |
David Tolnay | 5533772 | 2016-09-11 12:58:56 -0700 | [diff] [blame^] | 103 | } |
| 104 | nom::IResult::Error(err) => Err(root_cause(err)), |
| 105 | nom::IResult::Incomplete(_) => Err(format!("incomplete {}", name)), |
| 106 | }; |
| 107 | |
| 108 | fn root_cause(mut err: nom::Err<&str>) -> String { |
| 109 | loop { |
| 110 | match err { |
| 111 | nom::Err::Code(kind) => { |
| 112 | return format!("failed to parse {:?}", kind); |
| 113 | } |
| 114 | nom::Err::Position(kind, pos) => { |
| 115 | return format!("failed to parse {:?}: {:?}", kind, pos); |
| 116 | } |
| 117 | nom::Err::Node(_, next) | |
| 118 | nom::Err::NodePosition(_, _, next) => { |
| 119 | err = *next; |
| 120 | } |
David Tolnay | c94c38a | 2016-09-05 17:02:03 -0700 | [diff] [blame] | 121 | } |
David Tolnay | 7ebb9fb | 2016-09-03 12:07:47 -0700 | [diff] [blame] | 122 | } |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 123 | } |
David Tolnay | 35161ff | 2016-09-03 11:33:15 -0700 | [diff] [blame] | 124 | } |
| 125 | } |