mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
Fix stop_watch on linux
This commit is contained in:
parent
9b3e912d67
commit
15973f1a55
8 changed files with 29 additions and 17 deletions
|
@ -20,7 +20,6 @@ use ide_db::{
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use profile::{memory_usage, Bytes};
|
use profile::{memory_usage, Bytes};
|
||||||
use std::env;
|
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
use syntax::{ast, Parse, SyntaxNode};
|
use syntax::{ast, Parse, SyntaxNode};
|
||||||
use triomphe::Arc;
|
use triomphe::Arc;
|
||||||
|
|
|
@ -29,11 +29,10 @@ impl StopWatch {
|
||||||
// When debugging rust-analyzer using rr, the perf-related syscalls cause it to abort.
|
// When debugging rust-analyzer using rr, the perf-related syscalls cause it to abort.
|
||||||
// We allow disabling perf by setting the env var `RA_DISABLE_PERF`.
|
// We allow disabling perf by setting the env var `RA_DISABLE_PERF`.
|
||||||
|
|
||||||
use once_cell::sync::Lazy;
|
use std::sync::OnceLock;
|
||||||
static PERF_ENABLED: Lazy<bool> =
|
static PERF_ENABLED: OnceLock<bool> = OnceLock::new();
|
||||||
Lazy::new(|| std::env::var_os("RA_DISABLE_PERF").is_none());
|
|
||||||
|
|
||||||
if *PERF_ENABLED {
|
if *PERF_ENABLED.get_or_init(|| std::env::var_os("RA_DISABLE_PERF").is_none()) {
|
||||||
let mut counter = perf_event::Builder::new()
|
let mut counter = perf_event::Builder::new()
|
||||||
.build()
|
.build()
|
||||||
.map_err(|err| eprintln!("Failed to create perf counter: {err}"))
|
.map_err(|err| eprintln!("Failed to create perf counter: {err}"))
|
||||||
|
|
|
@ -5,7 +5,10 @@ use std::{
|
||||||
|
|
||||||
use xshell::{cmd, Shell};
|
use xshell::{cmd, Shell};
|
||||||
|
|
||||||
use crate::{flags, project_root};
|
use crate::{
|
||||||
|
flags::{self, CodegenType},
|
||||||
|
project_root,
|
||||||
|
};
|
||||||
|
|
||||||
pub(crate) mod assists_doc_tests;
|
pub(crate) mod assists_doc_tests;
|
||||||
pub(crate) mod diagnostics_docs;
|
pub(crate) mod diagnostics_docs;
|
||||||
|
@ -175,9 +178,8 @@ fn reformat(text: String) -> String {
|
||||||
stdout
|
stdout
|
||||||
}
|
}
|
||||||
|
|
||||||
fn add_preamble(generator: &'static str, mut text: String) -> String {
|
fn add_preamble(cg: CodegenType, mut text: String) -> String {
|
||||||
let preamble =
|
let preamble = format!("//! Generated by `cargo codegen {cg}`, do not edit by hand.\n\n");
|
||||||
format!("//! Generated by `cargo codegen {generator}`, do not edit by hand.\n\n");
|
|
||||||
text.insert_str(0, &preamble);
|
text.insert_str(0, &preamble);
|
||||||
text
|
text
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,7 @@ r#####"
|
||||||
buf.push_str(&test)
|
buf.push_str(&test)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let buf = add_preamble("assists-doc-tests", reformat(buf));
|
let buf = add_preamble(crate::flags::CodegenType::AssistsDocTests, reformat(buf));
|
||||||
ensure_file_contents(
|
ensure_file_contents(
|
||||||
&project_root().join("crates/ide-assists/src/tests/generated.rs"),
|
&project_root().join("crates/ide-assists/src/tests/generated.rs"),
|
||||||
&buf,
|
&buf,
|
||||||
|
@ -59,7 +59,7 @@ r#####"
|
||||||
// a release.
|
// a release.
|
||||||
|
|
||||||
let contents = add_preamble(
|
let contents = add_preamble(
|
||||||
"sourcegen_assists_docs",
|
crate::flags::CodegenType::AssistsDocTests,
|
||||||
assists.into_iter().map(|it| it.to_string()).collect::<Vec<_>>().join("\n\n"),
|
assists.into_iter().map(|it| it.to_string()).collect::<Vec<_>>().join("\n\n"),
|
||||||
);
|
);
|
||||||
let dst = project_root().join("docs/user/generated_assists.adoc");
|
let dst = project_root().join("docs/user/generated_assists.adoc");
|
||||||
|
|
|
@ -12,7 +12,7 @@ pub(crate) fn generate(check: bool) {
|
||||||
if !check {
|
if !check {
|
||||||
let contents =
|
let contents =
|
||||||
diagnostics.into_iter().map(|it| it.to_string()).collect::<Vec<_>>().join("\n\n");
|
diagnostics.into_iter().map(|it| it.to_string()).collect::<Vec<_>>().join("\n\n");
|
||||||
let contents = add_preamble("diagnostics-docs", contents);
|
let contents = add_preamble(crate::flags::CodegenType::DiagnosticsDocs, contents);
|
||||||
let dst = project_root().join("docs/user/generated_diagnostic.adoc");
|
let dst = project_root().join("docs/user/generated_diagnostic.adoc");
|
||||||
fs::write(dst, contents).unwrap();
|
fs::write(dst, contents).unwrap();
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ fn generate_tokens(grammar: &AstSrc) -> String {
|
||||||
});
|
});
|
||||||
|
|
||||||
add_preamble(
|
add_preamble(
|
||||||
"grammar",
|
crate::flags::CodegenType::Grammar,
|
||||||
reformat(
|
reformat(
|
||||||
quote! {
|
quote! {
|
||||||
use crate::{SyntaxKind::{self, *}, SyntaxToken, ast::AstToken};
|
use crate::{SyntaxKind::{self, *}, SyntaxToken, ast::AstToken};
|
||||||
|
@ -328,7 +328,7 @@ fn generate_nodes(kinds: KindsSrc<'_>, grammar: &AstSrc) -> String {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let res = add_preamble("grammar", reformat(res));
|
let res = add_preamble(crate::flags::CodegenType::Grammar, reformat(res));
|
||||||
res.replace("#[derive", "\n#[derive")
|
res.replace("#[derive", "\n#[derive")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -458,7 +458,7 @@ fn generate_syntax_kinds(grammar: KindsSrc<'_>) -> String {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
add_preamble("grammar", reformat(ast.to_string()))
|
add_preamble(crate::flags::CodegenType::Grammar, reformat(ast.to_string()))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn to_upper_snake_case(s: &str) -> String {
|
fn to_upper_snake_case(s: &str) -> String {
|
||||||
|
|
|
@ -73,7 +73,7 @@ pub struct LintGroup {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
generate_descriptor_clippy(&mut contents, &lints_json);
|
generate_descriptor_clippy(&mut contents, &lints_json);
|
||||||
|
|
||||||
let contents = add_preamble("lint-definitions", reformat(contents));
|
let contents = add_preamble(crate::flags::CodegenType::LintDefinitions, reformat(contents));
|
||||||
|
|
||||||
let destination = project_root().join(DESTINATION);
|
let destination = project_root().join(DESTINATION);
|
||||||
ensure_file_contents(destination.as_path(), &contents, check);
|
ensure_file_contents(destination.as_path(), &contents, check);
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#![allow(unreachable_pub)]
|
#![allow(unreachable_pub)]
|
||||||
|
|
||||||
use std::str::FromStr;
|
use std::{fmt, str::FromStr};
|
||||||
|
|
||||||
use crate::install::{ClientOpt, ServerOpt};
|
use crate::install::{ClientOpt, ServerOpt};
|
||||||
|
|
||||||
|
@ -187,6 +187,18 @@ pub enum CodegenType {
|
||||||
LintDefinitions,
|
LintDefinitions,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for CodegenType {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
|
match self {
|
||||||
|
Self::All => write!(f, "all"),
|
||||||
|
Self::Grammar => write!(f, "grammar"),
|
||||||
|
Self::AssistsDocTests => write!(f, "assists-doc-tests"),
|
||||||
|
Self::DiagnosticsDocs => write!(f, "diagnostics-docs"),
|
||||||
|
Self::LintDefinitions => write!(f, "lint-definitions"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl FromStr for CodegenType {
|
impl FromStr for CodegenType {
|
||||||
type Err = String;
|
type Err = String;
|
||||||
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||||
|
|
Loading…
Reference in a new issue