2017-01-16 14:50:27 +13:00
// rustfmt-normalize_comments: true
2018-07-18 12:09:50 +12:00
// rustfmt-format_macro_matchers: true
2016-01-22 13:40:26 -06:00
itemmacro! ( this , is . now ( ) . formatted ( yay ) ) ;
2015-09-14 22:53:30 +02:00
2016-01-24 13:11:18 -06:00
itemmacro! ( really , long . aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabbb ( ) . is . formatted ( ) ) ;
itemmacro! { this , is . bracket ( ) . formatted ( ) }
2016-03-27 14:45:55 +02:00
peg_file ! modname ( " mygrammarfile.rustpeg " ) ;
2015-09-14 22:53:30 +02:00
fn main ( ) {
foo! ( ) ;
2018-03-28 18:14:51 +09:00
foo! ( , ) ;
2015-09-14 22:53:30 +02:00
bar! ( a , b , c ) ;
2017-06-23 12:57:34 +09:00
bar! ( a , b , c , ) ;
2015-09-14 22:53:30 +02:00
baz! ( 1 + 2 + 3 , quux . kaas ( ) ) ;
quux! ( AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA , BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB ) ;
kaas! ( /* comments */ a /* post macro */ , b /* another */ ) ;
trailingcomma! ( a , b , c , ) ;
2017-10-27 16:35:40 +09:00
// Preserve trailing comma only when necessary.
ok! ( file . seek (
SeekFrom ::Start (
table . map ( | table | fixture . offset ( table ) ) . unwrap_or ( 0 ) ,
)
) ) ;
2015-09-14 22:53:30 +02:00
noexpr! ( i am not an expression , OK ? ) ;
vec! [ a , b , c ] ;
vec! [ AAAAAA , AAAAAA , AAAAAA , AAAAAA , AAAAAA , AAAAAA , AAAAAA , AAAAAA , AAAAAA ,
BBBBB , 5 , 100 - 30 , 1.33 , b , b , b ] ;
vec! [ a /* comment */ ] ;
2016-11-14 07:42:15 +03:00
// Trailing spaces after a comma
vec! [
a ,
] ;
2017-05-19 19:25:53 +09:00
vec! [ a ; b ] ;
vec! ( a ; b ) ;
vec! { a ; b } ;
vec! [ a , b ; c ] ;
vec! [ a ; b , c ] ;
2017-05-22 08:50:46 +09:00
vec! [ a ; ( | x | { let y = x + 1 ; let z = y + 1 ; z } ) ( 2 ) ] ;
vec! [ a ; xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ] ;
vec! [ a ; unsafe {
x + 1
} ] ;
2016-11-14 07:42:15 +03:00
unknown_bracket_macro__comma_should_not_be_stripped! [
a ,
] ;
2015-09-14 22:53:30 +02:00
foo ( makro! ( 1 , 3 ) ) ;
hamkaas! { ( ) } ;
macrowithbraces! { dont , format , me }
2015-10-27 23:41:32 -07:00
x! ( fn ) ;
2016-03-27 13:44:08 +02:00
some_macro! (
) ;
some_macro! [
] ;
some_macro! {
// comment
} ;
some_macro! {
// comment
} ;
2016-10-03 14:11:49 +10:00
some_macro! (
// comment
not function like
) ;
2017-05-24 01:18:15 +09:00
2017-06-18 02:35:18 +09:00
// #1712
let image = gray_image! (
00 , 01 , 02 ;
10 , 11 , 12 ;
20 , 21 , 22 ) ;
2017-05-08 06:44:48 +09:00
// #1092
chain! ( input , a :take ! ( max_size ) , | | [ ] ) ;
2018-05-24 00:13:56 +09:00
// #2727
foo! ( " bar " )
;
2016-03-27 13:44:08 +02:00
}
impl X {
empty_invoc! { }
2015-09-14 22:53:30 +02:00
}
2016-04-28 07:08:44 +12:00
2017-01-18 10:38:46 +13:00
fn issue_1279 ( ) {
println! ( " dsfs " ) ; // a comment
}
2017-05-15 22:55:01 +09:00
fn issue_1555 ( ) {
let hello = & format! ( " HTTP/1.1 200 OK \r \n Server: {} \r \n \r \n {} " ,
" 65454654654654654654654655464 " ,
" 4 " ) ;
}
2017-05-28 11:41:16 +09:00
fn issue1178 ( ) {
macro_rules ! foo {
( #[ $attr:meta ] $name :ident ) = > { }
}
foo! ( #[ doc = " bar " ] baz ) ;
}
2017-08-21 23:19:01 +09:00
2017-06-23 12:57:34 +09:00
fn issue1739 ( ) {
sql_function! ( add_rss_item ,
add_rss_item_t ,
( a : types ::Integer ,
b : types ::Timestamptz ,
c : types ::Text ,
d : types ::Text ,
e : types ::Text ) ) ;
w . slice_mut ( s! [ .. , init_size [ 1 ] - extreeeeeeeeeeeeeeeeeeeeeeeem .. init_size [ 1 ] , .. ] )
. par_map_inplace ( | el | * el = 0. ) ;
}
2017-08-21 23:19:01 +09:00
fn issue_1885 ( ) {
let threads = people . into_iter ( ) . map ( | name | {
chan_select! {
rx . recv ( ) = > { }
}
} ) . collect ::< Vec < _ > > ( ) ;
}
2017-08-25 22:35:22 +09:00
fn issue_1917 ( ) {
mod x {
quickcheck! {
fn test ( a : String , s : String , b : String ) -> TestResult {
if a . find ( & s ) . is_none ( ) {
TestResult ::from_bool ( true )
} else {
TestResult ::discard ( )
}
}
}
}
}
2017-08-27 13:44:49 +09:00
fn issue_1921 ( ) {
// Macro with tabs.
lazy_static! {
static ref ONE : u32 = 1 ;
static ref TWO : u32 = 2 ;
static ref THREE : u32 = 3 ;
static ref FOUR : u32 = {
let mut acc = 1 ;
acc + = 1 ;
acc + = 2 ;
acc
}
}
}
2017-06-23 12:57:34 +09:00
// #1577
fn issue1577 ( ) {
let json = json! ( {
" foo " : " bar " ,
} ) ;
}
gfx_pipeline! ( pipe {
vbuf : gfx ::VertexBuffer < Vertex > = ( ) ,
out : gfx ::RenderTarget < ColorFormat > = " Target0 " ,
} ) ;
2017-08-30 12:00:10 +09:00
// #1919
#[ test ]
fn __bindgen_test_layout_HandleWithDtor_open0_int_close0_instantiation ( ) {
assert_eq! (
::std ::mem ::size_of ::< HandleWithDtor < ::std ::os ::raw ::c_int > > ( ) ,
8 usize ,
concat! (
" Size of template specialization: " ,
stringify ! ( HandleWithDtor < :: std :: os :: raw :: c_int > )
)
) ;
assert_eq ! ( :: std :: mem :: align_of :: < HandleWithDtor < :: std :: os :: raw :: c_int > > ( ) , 8 usize , concat ! ( " Alignment of template specialization: " , stringify ! ( HandleWithDtor < :: std :: os :: raw :: c_int > ) ) ) ;
}
2017-10-05 19:44:45 +09:00
// #878
macro_rules ! try_opt {
( $expr :expr ) = > ( match $expr {
Some ( val ) = > val ,
None = > { return None ; }
} )
}
2017-11-30 22:12:55 +09:00
// #2214
// macro call whose argument is an array with trailing comma.
fn issue2214 ( ) {
make_test! ( str_searcher_ascii_haystack , " bb " , " abbcbbd " , [
Reject ( 0 , 1 ) ,
Match ( 1 , 3 ) ,
Reject ( 3 , 4 ) ,
Match ( 4 , 6 ) ,
Reject ( 6 , 7 ) ,
] ) ;
}
2017-12-01 13:28:16 +09:00
fn special_case_macros ( ) {
2018-01-18 00:50:16 +09:00
let p = eprint! ( ) ;
2017-12-05 16:45:01 -08:00
let q = eprint! ( " {} " , 1 ) ;
let r = eprint! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = eprint! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
let q = eprintln! ( " {} " , 1 ) ;
let r = eprintln! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = eprintln! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
let q = format! ( " {} " , 1 ) ;
let r = format! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = format! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
let q = format_args! ( " {} " , 1 ) ;
let r = format_args! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = format_args! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2017-12-05 16:49:48 -08:00
let q = print! ( " {} " , 1 ) ;
let r = print! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = print! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2017-12-05 16:45:01 -08:00
let q = println! ( " {} " , 1 ) ;
let r = println! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = println! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
let q = unreachable! ( " {} " , 1 ) ;
let r = unreachable! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
let s = unreachable! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
debug! ( " {} " , 1 ) ;
debug! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
debug! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
error! ( " {} " , 1 ) ;
error! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
error! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
info! ( " {} " , 1 ) ;
info! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
info! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
panic! ( " {} " , 1 ) ;
panic! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
panic! ( " {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} {} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
warn! ( " {} " , 1 ) ;
warn! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 ) ;
warn! ( " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2017-12-01 13:28:16 +09:00
2018-01-18 00:50:16 +09:00
assert! ( ) ;
assert! ( result = = 42 ) ;
2017-12-23 01:06:17 +00:00
assert! ( result = = 42 , " Ahoy there, {}! " , target ) ;
2017-12-27 21:19:42 +00:00
assert! ( result = = 42 , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
2017-12-23 01:06:17 +00:00
assert! ( result = = 42 , " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2018-01-18 00:50:16 +09:00
assert_eq! ( ) ;
assert_eq! ( left ) ;
assert_eq! ( left , right ) ;
2017-12-23 01:06:17 +00:00
assert_eq! ( left , right , " Ahoy there, {}! " , target ) ;
2017-12-27 21:19:42 +00:00
assert_eq! ( left , right , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
assert_eq! ( first_realllllllllllly_long_variable_that_doesnt_fit_one_one_line , second_reallllllllllly_long_variable_that_doesnt_fit_one_one_line , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
assert_eq! ( left + 42 , right , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
2017-12-23 01:06:17 +00:00
assert_eq! ( left , right , " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2017-12-06 22:42:33 -08:00
write! ( & mut s , " Ahoy there, {}! " , target ) ;
2017-12-27 21:19:42 +00:00
write! ( & mut s , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
2017-12-06 22:42:33 -08:00
write! ( & mut s , " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
writeln! ( & mut s , " Ahoy there, {}! " , target ) ;
2017-12-27 21:19:42 +00:00
writeln! ( & mut s , " Arr! While plunderin' the hold, we got '{}' when given '{}' (we expected '{}') " , result , input , expected ) ;
2017-12-06 22:42:33 -08:00
writeln! ( & mut s , " {}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{}{} " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 ) ;
2017-12-01 13:28:16 +09:00
}
2017-12-05 08:41:10 +09:00
// #1209
impl Foo {
/// foo
pub fn foo ( & self ) -> Bar < foo! ( ) > { }
}
2017-12-10 00:21:49 +09:00
// #819
fn macro_in_pattern_position ( ) {
let x = match y {
foo! ( ) = > ( ) ,
bar! ( a , b ,
c ) = > ( ) ,
bar! ( a
, b
, c
, ) = > ( ) ,
baz! ( 1 + 2 + 3 , quux . kaas ( )
) = > ( ) ,
quux! ( AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA , BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB ) = > ( ) ,
} ;
}
2018-01-01 19:51:30 +13:00
macro foo ( ) {
}
pub macro bar ( $x :ident + $y :expr ; ) {
fn foo ( $x : Foo ) {
long_function ( a_long_argument_to_a_long_function_is_what_this_is ( AAAAAAAAAAAAAAAAAAAAAAAAAAAA ) ,
$x . bar ( $y ) ) ;
}
}
2018-01-03 20:36:52 +13:00
macro foo ( ) {
// a comment
fn foo ( ) {
// another comment
bar ( ) ;
}
}
2018-02-04 08:52:50 +09:00
2018-03-31 17:54:44 +02:00
// #2574
macro_rules ! test {
( ) = > { { } }
}
2018-02-04 08:52:50 +09:00
macro lex_err ( $kind : ident $(, $body : expr ) * ) {
Err ( QlError ::LexError ( LexError ::$kind ( $( $body , ) * ) ) )
}
2018-02-24 11:48:07 +09:00
// Preserve trailing comma on item-level macro with `()` or `[]`.
methods! [ get , post , delete , ] ;
methods! ( get , post , delete , ) ;
2018-04-04 10:02:01 +08:00
2018-04-02 22:52:39 +09:00
// #2588
macro_rules ! m {
( ) = > {
r #"
test
" #
} ;
}
fn foo ( ) {
f! { r #"
test
" #};
}
2018-04-04 10:02:01 +08:00
// #2591
fn foo ( ) {
match 0 u32 {
0 = > ( ) ,
_ = > unreachable! ( /* obviously */ ) ,
}
}
fn foo ( ) {
let _ = column! ( /* here */ ) ;
}
2018-04-12 09:54:00 +09:00
// #2616
// Preserve trailing comma when using mixed layout for macro call.
fn foo ( ) {
foo! ( 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ) ;
foo! ( 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 , ) ;
}
2018-04-28 15:09:36 +09:00
// #2652
// Preserve trailing comma inside macro, even if it looks an array.
macro_rules ! bar {
( $m :ident ) = > {
$m ! ( [ a , b , c , d , e , f , g , h , i , j , k , l , m , n , o , p , q , r , s , t , u , v , w , x , y , z ] ) ;
} ;
}
2018-07-25 07:13:51 +09:00
// #2830
// Preserve trailing comma-less/ness inside nested macro.
named! (
do_parse_gsv < GsvData > ,
map_res! (
do_parse! (
number_of_sentences : map_res ! ( digit , parse_num ::< u16 > )
> > char ! ( ',' )
> > sentence_index : map_res ! ( digit , parse_num ::< u16 > )
> > char ! ( ',' )
> > total_number_of_sats : map_res ! ( digit , parse_num ::< u16 > )
> > char ! ( ',' )
> > sat0 : opt ! ( complete! ( parse_gsv_sat_info ) )
> > sat1 : opt ! ( complete! ( parse_gsv_sat_info ) )
> > sat2 : opt ! ( complete! ( parse_gsv_sat_info ) )
> > sat3 : opt ! ( complete! ( parse_gsv_sat_info ) )
> > (
number_of_sentences ,
sentence_index ,
total_number_of_sats ,
sat0 ,
sat1 ,
sat2 ,
sat3
)
) ,
construct_gsv_data
)
) ;
// #2857
convert_args! ( vec! ( 1 , 2 , 3 ) ) ;