mirror of
				https://github.com/rust-lang/rust-analyzer.git
				synced 2025-10-31 12:04:43 +00:00 
			
		
		
		
	 c58ddafe90
			
		
	
	
		c58ddafe90
		
	
	
	
	
		
			
			And make more queries non-interned. Also flip the default for queries, now the default is to not intern and to intern a query you need to say `invoke_interned`.
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| mod logger_db;
 | |
| use expect_test::expect;
 | |
| use logger_db::LoggerDb;
 | |
| 
 | |
| use query_group_macro::query_group;
 | |
| 
 | |
| #[derive(Clone, Debug, PartialEq, Eq)]
 | |
| pub struct Error;
 | |
| 
 | |
| #[query_group]
 | |
| pub trait ResultDatabase: salsa::Database {
 | |
|     #[salsa::input]
 | |
|     fn input_string(&self) -> String;
 | |
| 
 | |
|     #[salsa::invoke_interned(length)]
 | |
|     fn length(&self, key: ()) -> Result<usize, Error>;
 | |
| 
 | |
|     #[salsa::invoke_interned(length2)]
 | |
|     fn length2(&self, key: ()) -> Result<usize, Error>;
 | |
| }
 | |
| 
 | |
| fn length(db: &dyn ResultDatabase, _key: ()) -> Result<usize, Error> {
 | |
|     Ok(db.input_string().len())
 | |
| }
 | |
| 
 | |
| fn length2(db: &dyn ResultDatabase, _key: ()) -> Result<usize, Error> {
 | |
|     Ok(db.input_string().len())
 | |
| }
 | |
| 
 | |
| #[test]
 | |
| fn test_queries_with_results() {
 | |
|     let mut db = LoggerDb::default();
 | |
|     let input = "hello";
 | |
|     db.set_input_string(input.to_owned());
 | |
|     assert_eq!(db.length(()), Ok(input.len()));
 | |
|     assert_eq!(db.length2(()), Ok(input.len()));
 | |
| 
 | |
|     db.assert_logs(expect![[r#"
 | |
|         [
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(WillExecute { database_key: create_data_ResultDatabase(Id(0)) })",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(DidValidateMemoizedValue { database_key: create_data_ResultDatabase(Id(0)) })",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(WillExecute { database_key: length_shim(Id(800)) })",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|             "salsa_event(WillExecute { database_key: length2_shim(Id(c00)) })",
 | |
|             "salsa_event(WillCheckCancellation)",
 | |
|         ]"#]]);
 | |
| }
 |