Skip to content

Commit

Permalink
fix windows builds (helix-editor#6845)
Browse files Browse the repository at this point in the history
  • Loading branch information
pascalkuthe committed Apr 22, 2023
1 parent a1044a6 commit b7c62e2
Showing 1 changed file with 5 additions and 4 deletions.
9 changes: 5 additions & 4 deletions helix-loader/src/grammar.rs
Original file line number Diff line number Diff line change
Expand Up @@ -433,11 +433,12 @@ fn build_tree_sitter_library(
for (key, value) in compiler.env() {
command.env(key, value);
}

command.args(compiler.args());
// used to delay dropping the temporary object file until after the compilation is complete
let _path_guard;

if cfg!(all(windows, target_env = "msvc")) {
if compiler.is_like_msvc() {
command
.args(["/nologo", "/LD", "/I"])
.arg(header_path)
Expand All @@ -455,20 +456,20 @@ fn build_tree_sitter_library(
}
cpp_command.args(compiler.args());
let object_file =
library_path.with_file_name(format!("{}_scanner.o", &grammar.grammar_id));
library_path.with_file_name(format!("{}_scanner.obj", &grammar.grammar_id));
cpp_command
.args(["/nologo", "/LD", "/I"])
.arg(header_path)
.arg("/Od")
.arg("/utf-8")
.arg("/std:c++14")
.arg("/o")
.arg(&object_file)
.arg(format!("/Fo{}", object_file.display()))
.arg("/c")
.arg(scanner_path);
let output = cpp_command
.output()
.context("Failed to execute C++ compiler")?;

if !output.status.success() {
return Err(anyhow!(
"Parser compilation failed.\nStdout: {}\nStderr: {}",
Expand Down

0 comments on commit b7c62e2

Please sign in to comment.