Skip to content

Commit

Permalink
[naga wgsl-in] Test hex float suffix handling corner case.
Browse files Browse the repository at this point in the history
Test Naga's WGSL front end's handling of `h` and `f` suffixes on
hexadecimal float literals. WGSL permits these suffixes only if an
exponent is present, because otherwise `f` suffixes can be confused
with a hexadecimal digit.
  • Loading branch information
jimblandy committed Nov 22, 2023
1 parent 7246226 commit f82b324
Showing 1 changed file with 17 additions and 0 deletions.
17 changes: 17 additions & 0 deletions naga/src/front/wgsl/parse/lexer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -448,6 +448,7 @@ impl<'a> Lexer<'a> {
}

#[cfg(test)]
#[track_caller]
fn sub_test(source: &str, expected_tokens: &[Token]) {
let mut lex = Lexer::new(source);
for &token in expected_tokens {
Expand Down Expand Up @@ -674,6 +675,22 @@ fn test_tokens() {
Token::Operation('/'),
],
);

// Type suffixes are only allowed on hex float literals
// if you provided an exponent.
sub_test(
"0x1.2f 0x1.2f 0x1.2h 0x1.2H",
&[
// The 'f' suffixes are taken as a hex digit:
// the fractional part is 0x2f / 256.
Token::Number(Ok(Number::F32(1.0 + 0x2f as f32 / 256.0))),
Token::Number(Ok(Number::F32(1.0 + 0x2f as f32 / 256.0))),
Token::Number(Ok(Number::F32(1.125))),
Token::Word("h"),
Token::Number(Ok(Number::F32(1.125))),
Token::Word("H"),
],
)
}

#[test]
Expand Down

0 comments on commit f82b324

Please sign in to comment.