about summary refs log tree commit diff
diff options
context:
space:
mode:
authorRune Tynan <runetynan@gmail.com>2023-02-14 12:29:33 -0500
committerRune Tynan <runetynan@gmail.com>2023-02-14 12:29:33 -0500
commitbc81d582c972bc98be75be5b0f4f046ccaa6a34f (patch)
tree68d491a3c4bd6db780df30e8496522b655911cbc
parent37608f306ccb9acf63734d750059b8607a1f5f56 (diff)
downloadrust-bc81d582c972bc98be75be5b0f4f046ccaa6a34f.tar.gz
rust-bc81d582c972bc98be75be5b0f4f046ccaa6a34f.zip
Add v7 support to rust-analyzer
-rw-r--r--crates/proc-macro-api/src/version.rs13
1 files changed, 8 insertions, 5 deletions
diff --git a/crates/proc-macro-api/src/version.rs b/crates/proc-macro-api/src/version.rs
index 40125c2a512..ad0e8942c4b 100644
--- a/crates/proc-macro-api/src/version.rs
+++ b/crates/proc-macro-api/src/version.rs
@@ -120,17 +120,20 @@ pub fn read_version(dylib_path: &AbsPath) -> io::Result<String> {
     let version = u32::from_be_bytes([dot_rustc[4], dot_rustc[5], dot_rustc[6], dot_rustc[7]]);
     // Last supported version is:
     // https://github.com/rust-lang/rust/commit/0696e79f2740ad89309269b460579e548a5cd632
-    match version {
-        5 | 6 => {}
+    let snappy_portion = match version {
+        5 | 6 => &dot_rustc[8..],
+        7 => {
+            let len_bytes = &dot_rustc[8..12];
+            let data_len = u32::from_be_bytes(len_bytes.try_into().unwrap()) as usize;
+            &dot_rustc[12..data_len + 12]
+        },
         _ => {
             return Err(io::Error::new(
                 io::ErrorKind::InvalidData,
                 format!("unsupported metadata version {version}"),
             ));
         }
-    }
-
-    let snappy_portion = &dot_rustc[8..];
+    };
 
     let mut snappy_decoder = SnapDecoder::new(snappy_portion);