From e3afba5b7bccb4bf1f3a0327aa9ad91f16527250 Mon Sep 17 00:00:00 2001 From: Igor Matuszewski Date: Sun, 15 Oct 2017 23:27:17 +0200 Subject: [PATCH 1/3] Emit crate disambiguators in save-analysis data --- src/librustc_save_analysis/Cargo.toml | 2 +- src/librustc_save_analysis/dump_visitor.rs | 9 ++++++--- src/librustc_save_analysis/lib.rs | 17 ++++++++--------- 3 files changed, 15 insertions(+), 13 deletions(-) diff --git a/src/librustc_save_analysis/Cargo.toml b/src/librustc_save_analysis/Cargo.toml index 12897050164c9..a01659f3d46b7 100644 --- a/src/librustc_save_analysis/Cargo.toml +++ b/src/librustc_save_analysis/Cargo.toml @@ -15,7 +15,7 @@ rustc_data_structures = { path = "../librustc_data_structures" } rustc_typeck = { path = "../librustc_typeck" } syntax = { path = "../libsyntax" } syntax_pos = { path = "../libsyntax_pos" } -rls-data = "0.11" +rls-data = { git = "/~https://github.com/Xanewok/rls-data", branch = "crate-source" } rls-span = "0.4" # FIXME(#40527) should move rustc serialize out of tree rustc-serialize = "0.3" diff --git a/src/librustc_save_analysis/dump_visitor.rs b/src/librustc_save_analysis/dump_visitor.rs index ca44a088e2379..13787dbadd04a 100644 --- a/src/librustc_save_analysis/dump_visitor.rs +++ b/src/librustc_save_analysis/dump_visitor.rs @@ -46,8 +46,8 @@ use json_dumper::{JsonDumper, DumpOutput}; use span_utils::SpanUtils; use sig; -use rls_data::{CratePreludeData, Import, ImportKind, SpanData, Ref, RefKind, - Def, DefKind, Relation, RelationKind}; +use rls_data::{CratePreludeData, GlobalCrateId, Import, ImportKind, SpanData, + Ref, RefKind, Def, DefKind, Relation, RelationKind}; macro_rules! down_cast_data { ($id:ident, $kind:ident, $sp:expr) => { @@ -131,7 +131,10 @@ impl<'l, 'tcx: 'l, 'll, O: DumpOutput + 'll> DumpVisitor<'l, 'tcx, 'll, O> { }); let data = CratePreludeData { - crate_name: name.into(), + crate_id: GlobalCrateId { + name: name.into(), + disambiguator: self.tcx.sess.local_crate_disambiguator().to_string(), + }, crate_root: crate_root.unwrap_or("".to_owned()), external_crates: self.save_ctxt.get_external_crates(), span: self.span_from_span(krate.span), diff --git a/src/librustc_save_analysis/lib.rs b/src/librustc_save_analysis/lib.rs index 1c6007966afa3..886679f77d73e 100644 --- a/src/librustc_save_analysis/lib.rs +++ b/src/librustc_save_analysis/lib.rs @@ -63,7 +63,7 @@ use dump_visitor::DumpVisitor; use span_utils::SpanUtils; use rls_data::{Ref, RefKind, SpanData, MacroRef, Def, DefKind, Relation, RelationKind, - ExternalCrateData}; + ExternalCrateData, GlobalCrateId}; use rls_data::config::Config; @@ -82,10 +82,6 @@ pub enum Data { RelationData(Relation), } -macro_rules! option_try( - ($e:expr) => (match $e { Some(e) => e, None => return None }) -); - impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> { fn span_from_span(&self, span: Span) -> SpanData { use rls_span::{Row, Column}; @@ -119,9 +115,12 @@ impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> { }; let lo_loc = self.span_utils.sess.codemap().lookup_char_pos(span.lo()); result.push(ExternalCrateData { - name: self.tcx.crate_name(n).to_string(), - num: n.as_u32(), file_name: SpanUtils::make_path_string(&lo_loc.file.name), + num: n.as_u32(), + id: GlobalCrateId { + name: self.tcx.crate_name(n).to_string(), + disambiguator: self.tcx.crate_disambiguator(n).to_string(), + }, }); } @@ -725,8 +724,8 @@ impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> { // macro uses. let callsite = span.source_callsite(); let callsite_span = self.span_from_span(callsite); - let callee = option_try!(span.source_callee()); - let callee_span = option_try!(callee.span); + let callee = span.source_callee()?; + let callee_span = callee.span?; // Ignore attribute macros, their spans are usually mangled if let MacroAttribute(_) = callee.format { From 45fa7b26e8f298a542f460b88684797dc46078dd Mon Sep 17 00:00:00 2001 From: Igor Matuszewski Date: Fri, 27 Oct 2017 23:53:57 +0200 Subject: [PATCH 2/3] Use rls-data 0.12 --- src/Cargo.lock | 12 +++++++++++- src/librustc/ich/fingerprint.rs | 5 +++++ src/librustc_save_analysis/Cargo.toml | 2 +- src/librustc_save_analysis/dump_visitor.rs | 3 ++- src/librustc_save_analysis/lib.rs | 3 ++- 5 files changed, 21 insertions(+), 4 deletions(-) diff --git a/src/Cargo.lock b/src/Cargo.lock index 4dae5e89088f6..36e09e13143a6 100644 --- a/src/Cargo.lock +++ b/src/Cargo.lock @@ -1480,6 +1480,15 @@ dependencies = [ "serde_derive 1.0.15 (registry+/~https://github.com/rust-lang/crates.io-index)", ] +[[package]] +name = "rls-data" +version = "0.12.0" +source = "registry+/~https://github.com/rust-lang/crates.io-index" +dependencies = [ + "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", + "rustc-serialize 0.3.24 (registry+/~https://github.com/rust-lang/crates.io-index)", +] + [[package]] name = "rls-rustc" version = "0.1.1" @@ -1833,7 +1842,7 @@ name = "rustc_save_analysis" version = "0.0.0" dependencies = [ "log 0.3.8 (registry+/~https://github.com/rust-lang/crates.io-index)", - "rls-data 0.11.0 (registry+/~https://github.com/rust-lang/crates.io-index)", + "rls-data 0.12.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rustc 0.0.0", "rustc-serialize 0.3.24 (registry+/~https://github.com/rust-lang/crates.io-index)", @@ -2711,6 +2720,7 @@ source = "registry+/~https://github.com/rust-lang/crates.io-index" "checksum regex-syntax 0.4.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "ad890a5eef7953f55427c50575c680c42841653abd2b028b68cd223d157f62db" "checksum rls-analysis 0.7.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "bd4e96e3a7d4cf3f31d789080ddd88fbe3251df2feb168049a24eda8b6046ed8" "checksum rls-data 0.11.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "6aea328fa69702c1b0fc395f2c71eae954bf984ac1e418c72f69221b6e3d15ff" +"checksum rls-data 0.12.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "48257ceade23c2e01a3ca8d2fc4226101b107f6a3c868f829cf3fd2f204a1fe6" "checksum rls-rustc 0.1.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "b21ea952e9bf1569929abf1bb920262cde04b7b1b26d8e0260286302807299d2" "checksum rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "5d7c7046dc6a92f2ae02ed302746db4382e75131b9ce20ce967259f6b5867a6a" "checksum rls-vfs 0.4.4 (registry+/~https://github.com/rust-lang/crates.io-index)" = "ffd34691a510938bb67fe0444fb363103c73ffb31c121d1e16bc92d8945ea8ff" diff --git a/src/librustc/ich/fingerprint.rs b/src/librustc/ich/fingerprint.rs index f3bb3b385667e..3d089d8e75fb1 100644 --- a/src/librustc/ich/fingerprint.rs +++ b/src/librustc/ich/fingerprint.rs @@ -29,6 +29,11 @@ impl Fingerprint { self.0 } + #[inline] + pub fn as_value(&self) -> (u64, u64) { + (self.0, self.1) + } + #[inline] pub fn combine(self, other: Fingerprint) -> Fingerprint { // See https://stackoverflow.com/a/27952689 on why this function is diff --git a/src/librustc_save_analysis/Cargo.toml b/src/librustc_save_analysis/Cargo.toml index a01659f3d46b7..1b5ab10fc707d 100644 --- a/src/librustc_save_analysis/Cargo.toml +++ b/src/librustc_save_analysis/Cargo.toml @@ -15,7 +15,7 @@ rustc_data_structures = { path = "../librustc_data_structures" } rustc_typeck = { path = "../librustc_typeck" } syntax = { path = "../libsyntax" } syntax_pos = { path = "../libsyntax_pos" } -rls-data = { git = "/~https://github.com/Xanewok/rls-data", branch = "crate-source" } +rls-data = "0.12" rls-span = "0.4" # FIXME(#40527) should move rustc serialize out of tree rustc-serialize = "0.3" diff --git a/src/librustc_save_analysis/dump_visitor.rs b/src/librustc_save_analysis/dump_visitor.rs index 13787dbadd04a..a019864eccf6c 100644 --- a/src/librustc_save_analysis/dump_visitor.rs +++ b/src/librustc_save_analysis/dump_visitor.rs @@ -133,7 +133,8 @@ impl<'l, 'tcx: 'l, 'll, O: DumpOutput + 'll> DumpVisitor<'l, 'tcx, 'll, O> { let data = CratePreludeData { crate_id: GlobalCrateId { name: name.into(), - disambiguator: self.tcx.sess.local_crate_disambiguator().to_string(), + disambiguator: self.tcx.sess.local_crate_disambiguator() + .to_fingerprint().as_value(), }, crate_root: crate_root.unwrap_or("".to_owned()), external_crates: self.save_ctxt.get_external_crates(), diff --git a/src/librustc_save_analysis/lib.rs b/src/librustc_save_analysis/lib.rs index 886679f77d73e..9ebc5ae68d30b 100644 --- a/src/librustc_save_analysis/lib.rs +++ b/src/librustc_save_analysis/lib.rs @@ -119,7 +119,8 @@ impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> { num: n.as_u32(), id: GlobalCrateId { name: self.tcx.crate_name(n).to_string(), - disambiguator: self.tcx.crate_disambiguator(n).to_string(), + disambiguator: self.tcx.crate_disambiguator(n) + .to_fingerprint().as_value(), }, }); } From b4ffedee677605cf969fb5b1b0651534022e316d Mon Sep 17 00:00:00 2001 From: Igor Matuszewski Date: Mon, 30 Oct 2017 20:40:58 +0100 Subject: [PATCH 3/3] Update rls so it compiles with #45468 --- src/Cargo.lock | 48 +++++++++++------------------------------------- src/tools/rls | 2 +- 2 files changed, 12 insertions(+), 38 deletions(-) diff --git a/src/Cargo.lock b/src/Cargo.lock index 36e09e13143a6..9d1904b2ab91b 100644 --- a/src/Cargo.lock +++ b/src/Cargo.lock @@ -480,11 +480,11 @@ dependencies = [ [[package]] name = "derive-new" -version = "0.3.0" +version = "0.5.0" source = "registry+/~https://github.com/rust-lang/crates.io-index" dependencies = [ - "quote 0.2.3 (registry+/~https://github.com/rust-lang/crates.io-index)", - "syn 0.8.7 (registry+/~https://github.com/rust-lang/crates.io-index)", + "quote 0.3.15 (registry+/~https://github.com/rust-lang/crates.io-index)", + "syn 0.11.11 (registry+/~https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1339,11 +1339,6 @@ name = "quine-mc_cluskey" version = "0.2.4" source = "registry+/~https://github.com/rust-lang/crates.io-index" -[[package]] -name = "quote" -version = "0.2.3" -source = "registry+/~https://github.com/rust-lang/crates.io-index" - [[package]] name = "quote" version = "0.3.15" @@ -1445,8 +1440,8 @@ dependencies = [ "lazy_static 0.2.8 (registry+/~https://github.com/rust-lang/crates.io-index)", "log 0.3.8 (registry+/~https://github.com/rust-lang/crates.io-index)", "racer 2.0.10 (registry+/~https://github.com/rust-lang/crates.io-index)", - "rls-analysis 0.7.0 (registry+/~https://github.com/rust-lang/crates.io-index)", - "rls-data 0.11.0 (registry+/~https://github.com/rust-lang/crates.io-index)", + "rls-analysis 0.7.1 (registry+/~https://github.com/rust-lang/crates.io-index)", + "rls-data 0.12.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rls-rustc 0.1.1 (registry+/~https://github.com/rust-lang/crates.io-index)", "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rls-vfs 0.4.4 (registry+/~https://github.com/rust-lang/crates.io-index)", @@ -1459,19 +1454,19 @@ dependencies = [ [[package]] name = "rls-analysis" -version = "0.7.0" +version = "0.7.1" source = "registry+/~https://github.com/rust-lang/crates.io-index" dependencies = [ - "derive-new 0.3.0 (registry+/~https://github.com/rust-lang/crates.io-index)", + "derive-new 0.5.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "log 0.3.8 (registry+/~https://github.com/rust-lang/crates.io-index)", - "rls-data 0.11.0 (registry+/~https://github.com/rust-lang/crates.io-index)", + "rls-data 0.12.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", "rustc-serialize 0.3.24 (registry+/~https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "rls-data" -version = "0.11.0" +version = "0.12.0" source = "registry+/~https://github.com/rust-lang/crates.io-index" dependencies = [ "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", @@ -1480,15 +1475,6 @@ dependencies = [ "serde_derive 1.0.15 (registry+/~https://github.com/rust-lang/crates.io-index)", ] -[[package]] -name = "rls-data" -version = "0.12.0" -source = "registry+/~https://github.com/rust-lang/crates.io-index" -dependencies = [ - "rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)", - "rustc-serialize 0.3.24 (registry+/~https://github.com/rust-lang/crates.io-index)", -] - [[package]] name = "rls-rustc" version = "0.1.1" @@ -2180,15 +2166,6 @@ name = "strsim" version = "0.6.0" source = "registry+/~https://github.com/rust-lang/crates.io-index" -[[package]] -name = "syn" -version = "0.8.7" -source = "registry+/~https://github.com/rust-lang/crates.io-index" -dependencies = [ - "quote 0.2.3 (registry+/~https://github.com/rust-lang/crates.io-index)", - "unicode-xid 0.0.3 (registry+/~https://github.com/rust-lang/crates.io-index)", -] - [[package]] name = "syn" version = "0.11.11" @@ -2622,7 +2599,7 @@ source = "registry+/~https://github.com/rust-lang/crates.io-index" "checksum custom_derive 0.1.7 (registry+/~https://github.com/rust-lang/crates.io-index)" = "ef8ae57c4978a2acd8b869ce6b9ca1dfe817bff704c220209fdef2c0b75a01b9" "checksum dbghelp-sys 0.2.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "97590ba53bcb8ac28279161ca943a924d1fd4a8fb3fa63302591647c4fc5b850" "checksum debug_unreachable 0.1.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "9a032eac705ca39214d169f83e3d3da290af06d8d1d344d1baad2fd002dca4b3" -"checksum derive-new 0.3.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "41be6ca3b99e0c0483fb2389685448f650459c3ecbe4e18d7705d8010ec4ab8e" +"checksum derive-new 0.5.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "415f627ab054041c3eb748c2e1da0ef751989f5f0c386b63a098e545854a98ba" "checksum diff 0.1.10 (registry+/~https://github.com/rust-lang/crates.io-index)" = "0a515461b6c8c08419850ced27bc29e86166dcdcde8fbe76f8b1f0589bb49472" "checksum docopt 0.8.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "3b5b93718f8b3e5544fcc914c43de828ca6c6ace23e0332c6080a2977b49787a" "checksum dtoa 0.4.2 (registry+/~https://github.com/rust-lang/crates.io-index)" = "09c3753c3db574d215cba4ea76018483895d7bff25a31b49ba45db21c48e50ab" @@ -2709,7 +2686,6 @@ source = "registry+/~https://github.com/rust-lang/crates.io-index" "checksum pulldown-cmark 0.1.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "a656fdb8b6848f896df5e478a0eb9083681663e37dcb77dd16981ff65329fe8b" "checksum quick-error 1.2.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "eda5fe9b71976e62bc81b781206aaa076401769b2143379d3eb2118388babac4" "checksum quine-mc_cluskey 0.2.4 (registry+/~https://github.com/rust-lang/crates.io-index)" = "07589615d719a60c8dd8a4622e7946465dfef20d1a428f969e3443e7386d5f45" -"checksum quote 0.2.3 (registry+/~https://github.com/rust-lang/crates.io-index)" = "4c5cf478fe1006dbcc72567121d23dbdae5f1632386068c5c86ff4f645628504" "checksum quote 0.3.15 (registry+/~https://github.com/rust-lang/crates.io-index)" = "7a6e920b65c65f10b2ae65c831a81a073a89edd28c7cce89475bff467ab4167a" "checksum racer 2.0.10 (registry+/~https://github.com/rust-lang/crates.io-index)" = "f120c7510ef7aff254aeb06067fb6fac573ec96a1660e194787cf9dced412bf0" "checksum rand 0.3.16 (registry+/~https://github.com/rust-lang/crates.io-index)" = "eb250fd207a4729c976794d03db689c9be1d634ab5a1c9da9492a13d8fecbcdf" @@ -2718,8 +2694,7 @@ source = "registry+/~https://github.com/rust-lang/crates.io-index" "checksum regex 0.2.2 (registry+/~https://github.com/rust-lang/crates.io-index)" = "1731164734096285ec2a5ec7fea5248ae2f5485b3feeb0115af4fda2183b2d1b" "checksum regex-syntax 0.3.9 (registry+/~https://github.com/rust-lang/crates.io-index)" = "f9ec002c35e86791825ed294b50008eea9ddfc8def4420124fbc6b08db834957" "checksum regex-syntax 0.4.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "ad890a5eef7953f55427c50575c680c42841653abd2b028b68cd223d157f62db" -"checksum rls-analysis 0.7.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "bd4e96e3a7d4cf3f31d789080ddd88fbe3251df2feb168049a24eda8b6046ed8" -"checksum rls-data 0.11.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "6aea328fa69702c1b0fc395f2c71eae954bf984ac1e418c72f69221b6e3d15ff" +"checksum rls-analysis 0.7.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "f3e4c03af262074324e732ba2313ce74968b4262b060367ed4d52940b6586fa1" "checksum rls-data 0.12.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "48257ceade23c2e01a3ca8d2fc4226101b107f6a3c868f829cf3fd2f204a1fe6" "checksum rls-rustc 0.1.1 (registry+/~https://github.com/rust-lang/crates.io-index)" = "b21ea952e9bf1569929abf1bb920262cde04b7b1b26d8e0260286302807299d2" "checksum rls-span 0.4.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "5d7c7046dc6a92f2ae02ed302746db4382e75131b9ce20ce967259f6b5867a6a" @@ -2750,7 +2725,6 @@ source = "registry+/~https://github.com/rust-lang/crates.io-index" "checksum strings 0.1.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "da75d8bf2c4d210d63dd09581a041b036001f9f6e03d9b151dbff810fb7ba26a" "checksum strsim 0.6.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "b4d15c810519a91cf877e7e36e63fe068815c678181439f2f29e2562147c3694" "checksum syn 0.11.11 (registry+/~https://github.com/rust-lang/crates.io-index)" = "d3b891b9015c88c576343b9b3e41c2c11a51c219ef067b264bd9c8aa9b441dad" -"checksum syn 0.8.7 (registry+/~https://github.com/rust-lang/crates.io-index)" = "6ae6fb0dcc9bd85f89a1a4adc0df2fd90c90c98849d61433983dd7a9df6363f7" "checksum synom 0.11.3 (registry+/~https://github.com/rust-lang/crates.io-index)" = "a393066ed9010ebaed60b9eafa373d4b1baac186dd7e008555b0f702b51945b6" "checksum syntex_errors 0.52.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "9e52bffe6202cfb67587784cf23e0ec5bf26d331eef4922a16d5c42e12aa1e9b" "checksum syntex_pos 0.52.0 (registry+/~https://github.com/rust-lang/crates.io-index)" = "955ef4b16af4c468e4680d1497f873ff288f557d338180649e18f915af5e15ac" diff --git a/src/tools/rls b/src/tools/rls index e0348594a7245..48fd42fe92175 160000 --- a/src/tools/rls +++ b/src/tools/rls @@ -1 +1 @@ -Subproject commit e0348594a724571f1d2387e03943efeb4df20e12 +Subproject commit 48fd42fe92175ce93a5b67f78c195254ee94493d