rust/tests/ui/string_lit_as_bytes.rs

50 lines
1.2 KiB
Rust
Raw Normal View History

2023-04-19 21:09:27 -05:00
//@aux-build:macro_rules.rs
#![allow(clippy::needless_raw_string_hashes, dead_code, unused_variables)]
#![warn(clippy::string_lit_as_bytes)]
2023-04-19 21:09:27 -05:00
#[macro_use]
extern crate macro_rules;
2023-04-18 02:14:00 -05:00
macro_rules! b {
($b:literal) => {
2023-04-19 21:09:27 -05:00
const B: &[u8] = $b.as_bytes();
2023-04-18 10:12:34 -05:00
};
2023-04-18 02:14:00 -05:00
}
fn str_lit_as_bytes() {
let bs = "hello there".as_bytes();
let bs = r###"raw string with 3# plus " ""###.as_bytes();
let bs = "lit to string".to_string().into_bytes();
let bs = "lit to owned".to_owned().into_bytes();
2023-04-19 21:09:27 -05:00
b!("warning");
string_lit_as_bytes!("no warning");
2023-04-18 02:14:00 -05:00
// no warning, because these cannot be written as byte string literals:
let ubs = "".as_bytes();
let ubs = "hello there! this is a very long string".as_bytes();
let ubs = "".to_string().into_bytes();
let ubs = "this is also too long and shouldn't be fixed".to_string().into_bytes();
let strify = stringify!(foobar).as_bytes();
let current_version = env!("CARGO_PKG_VERSION").as_bytes();
let includestr = include_str!("string_lit_as_bytes.rs").as_bytes();
let _ = "string with newline\t\n".as_bytes();
let _ = match "x".as_bytes() {
b"xx" => 0,
[b'x', ..] => 1,
_ => 2,
};
}
fn main() {}