From 4ad87e9a866f202cc42e7a8ceead2c2fb7c9abad Mon Sep 17 00:00:00 2001 From: Young-Flash Date: Wed, 11 Dec 2024 14:21:17 +0800 Subject: [PATCH 1/3] minor: move moon_install_bin project into src --- .../test_cases/moon_install_bin.in/author1.in/moon.mod.json | 3 ++- .../moon_install_bin.in/author1.in/{ => src}/lib/hello.mbt | 0 .../author1.in/{ => src}/lib/moon.pkg.json | 0 .../author1.in/{ => src}/main-js/main.mbt | 0 .../author1.in/{ => src}/main-js/moon.pkg.json | 0 .../author1.in/{ => src}/main-native/main.mbt | 0 .../author1.in/{ => src}/main-native/moon.pkg.json | 0 .../author1.in/{ => src}/main-wasm/main.mbt | 0 .../author1.in/{ => src}/main-wasm/moon.pkg.json | 0 .../test_cases/moon_install_bin.in/author2.in/moon.mod.json | 5 +++-- .../moon_install_bin.in/author2.in/{ => src}/lib/hello.mbt | 0 .../author2.in/{ => src}/lib/moon.pkg.json | 0 .../author2.in/{ => src}/main-js/main.mbt | 0 .../author2.in/{ => src}/main-js/moon.pkg.json | 0 .../author2.in/{ => src}/main-native/main.mbt | 0 .../author2.in/{ => src}/main-native/moon.pkg.json | 0 .../author2.in/{ => src}/main-wasm/main.mbt | 0 .../author2.in/{ => src}/main-wasm/moon.pkg.json | 0 .../moon_install_bin.in/user.in/main/moon.pkg.json | 2 +- 19 files changed, 6 insertions(+), 4 deletions(-) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/lib/hello.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/lib/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-js/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-js/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-native/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-native/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-wasm/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author1.in/{ => src}/main-wasm/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/lib/hello.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/lib/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-js/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-js/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-native/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-native/moon.pkg.json (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-wasm/main.mbt (100%) rename crates/moon/tests/test_cases/moon_install_bin.in/author2.in/{ => src}/main-wasm/moon.pkg.json (100%) diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/moon.mod.json b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/moon.mod.json index 6f5ae316..3cd41aa4 100644 --- a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/moon.mod.json +++ b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/moon.mod.json @@ -5,5 +5,6 @@ "repository": "", "license": "Apache-2.0", "keywords": [], - "description": "" + "description": "", + "source": "src" } \ No newline at end of file diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/lib/hello.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/lib/hello.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/lib/hello.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/lib/hello.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/lib/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/lib/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/lib/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/lib/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-js/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-js/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-js/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-js/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-js/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-js/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-js/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-js/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-native/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-native/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-native/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-native/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-native/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-native/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-native/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-native/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-wasm/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-wasm/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-wasm/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-wasm/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-wasm/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-wasm/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author1.in/main-wasm/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author1.in/src/main-wasm/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/moon.mod.json b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/moon.mod.json index b5e34eaf..71751be2 100644 --- a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/moon.mod.json +++ b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/moon.mod.json @@ -5,5 +5,6 @@ "repository": "", "license": "Apache-2.0", "keywords": [], - "description": "" -} \ No newline at end of file + "description": "", + "source": "src" +} diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/lib/hello.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/lib/hello.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/lib/hello.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/lib/hello.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/lib/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/lib/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/lib/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/lib/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-js/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-js/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-js/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-js/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-js/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-js/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-js/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-js/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-native/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-native/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-native/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-native/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-native/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-native/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-native/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-native/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-wasm/main.mbt b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-wasm/main.mbt similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-wasm/main.mbt rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-wasm/main.mbt diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-wasm/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-wasm/moon.pkg.json similarity index 100% rename from crates/moon/tests/test_cases/moon_install_bin.in/author2.in/main-wasm/moon.pkg.json rename to crates/moon/tests/test_cases/moon_install_bin.in/author2.in/src/main-wasm/moon.pkg.json diff --git a/crates/moon/tests/test_cases/moon_install_bin.in/user.in/main/moon.pkg.json b/crates/moon/tests/test_cases/moon_install_bin.in/user.in/main/moon.pkg.json index 1cae2c2c..db4ad0c8 100644 --- a/crates/moon/tests/test_cases/moon_install_bin.in/user.in/main/moon.pkg.json +++ b/crates/moon/tests/test_cases/moon_install_bin.in/user.in/main/moon.pkg.json @@ -7,7 +7,7 @@ { "input": [], "output": ["1.txt"], - "command": "node ../author1.in/main-js.js" + "command": "../author1.in/main-js" } ] } From 9a344882352a05216c147913069c8da83504b585 Mon Sep 17 00:00:00 2001 From: Young-Flash Date: Wed, 11 Dec 2024 14:31:24 +0800 Subject: [PATCH 2/3] internal: refactor to script bin --- crates/moon/tests/test_cases/mod.rs | 42 +++++++--- crates/moonbuild/src/gen/gen_build.rs | 80 ++++++++++++++----- crates/moonbuild/src/pre_build.rs | 15 ++++ .../template/moon_bin_script_template/unix.sh | 2 + .../moon_bin_script_template/windows.ps1 | 1 + 5 files changed, 107 insertions(+), 33 deletions(-) create mode 100755 crates/moonbuild/template/moon_bin_script_template/unix.sh create mode 100755 crates/moonbuild/template/moon_bin_script_template/windows.ps1 diff --git a/crates/moon/tests/test_cases/mod.rs b/crates/moon/tests/test_cases/mod.rs index aecb8eb6..fd92ec1d 100644 --- a/crates/moon/tests/test_cases/mod.rs +++ b/crates/moon/tests/test_cases/mod.rs @@ -8065,11 +8065,29 @@ fn test_moon_install_bin() { let top_dir = TestDir::new("moon_install_bin.in"); let dir = top_dir.join("user.in"); - let _1 = top_dir.join("author2.in").join("author2-native.exe"); - let _2 = top_dir.join("author2.in").join("author2-js.js"); - let _3 = top_dir.join("author2.in").join("author2-wasm.wasm"); - let _4 = top_dir.join("author1.in").join("this-is-wasm.wasm"); - let _5 = top_dir.join("author1.in").join("main-js.js"); + let mut _1 = PathBuf::from(""); + let mut _2 = PathBuf::from(""); + let mut _3 = PathBuf::from(""); + let mut _4 = PathBuf::from(""); + let mut _5 = PathBuf::from(""); + + #[cfg(unix)] + { + _1 = top_dir.join("author2.in").join("author2-native"); + _2 = top_dir.join("author2.in").join("author2-js"); + _3 = top_dir.join("author2.in").join("author2-wasm"); + _4 = top_dir.join("author1.in").join("this-is-wasm"); + _5 = top_dir.join("author1.in").join("main-js"); + } + + #[cfg(target_os = "windows")] + { + _1 = top_dir.join("author2.in").join("author2-native.ps1"); + _2 = top_dir.join("author2.in").join("author2-js.ps1"); + _3 = top_dir.join("author2.in").join("author2-wasm.ps1"); + _4 = top_dir.join("author1.in").join("this-is-wasm.ps1"); + _5 = top_dir.join("author1.in").join("main-js.ps1"); + } // moon check should auto install bin deps get_stdout(&dir, ["check"]); @@ -8103,13 +8121,13 @@ fn test_moon_install_bin() { assert!(_5.exists()); check( - get_stderr(&dir, ["build"]), + get_stderr(&dir, ["build", "--sort-input"]), expect![[r#" - main-js - lib Hello, world! - () - Executed 1 pre-build task, now up to date - Finished. moon: ran 17 tasks, now up to date - "#]], + main-js + lib Hello, world! + () + Executed 1 pre-build task, now up to date + Finished. moon: ran 17 tasks, now up to date + "#]], ); } diff --git a/crates/moonbuild/src/gen/gen_build.rs b/crates/moonbuild/src/gen/gen_build.rs index d8d77578..d6322842 100644 --- a/crates/moonbuild/src/gen/gen_build.rs +++ b/crates/moonbuild/src/gen/gen_build.rs @@ -16,7 +16,7 @@ // // For inquiries, you can contact us via e-mail at jichuruanjian@idea.edu.cn. -use anyhow::{bail, Ok}; +use anyhow::{bail, Context, Ok}; use moonutil::module::ModuleDB; use moonutil::package::{JsFormat, Package}; @@ -26,7 +26,9 @@ use crate::gen::MiAlias; use std::path::{Path, PathBuf}; use std::rc::Rc; -use moonutil::common::{BuildOpt, MoonbuildOpt, MooncOpt, MOONBITLANG_CORE, MOON_PKG_JSON}; +use moonutil::common::{ + BuildOpt, MoonbuildOpt, MooncOpt, TargetBackend, MOONBITLANG_CORE, MOON_PKG_JSON, +}; use n2::graph::{self as n2graph, Build, BuildIns, BuildOuts, FileLoc}; use n2::load::State; use n2::smallmap::SmallMap; @@ -476,28 +478,64 @@ pub fn gen_n2_build_state( // if we need to install the artifact to a specific path if let Some(install_path) = item.install_path.as_ref() { - let artifact_output_path = install_path - .join(if let Some(bin_name) = &item.bin_name { - bin_name.clone() - } else { - PathBuf::from(&item.out) - .file_name() - .unwrap() - .to_str() - .unwrap() - .to_string() - }) + let bin_script_content = if cfg!(target_os = "windows") { + include_str!(concat!( + env!("CARGO_MANIFEST_DIR"), + "/../moonbuild/template/moon_bin_script_template/windows.ps1" + )) + } else { + include_str!(concat!( + env!("CARGO_MANIFEST_DIR"), + "/../moonbuild/template/moon_bin_script_template/unix.sh" + )) + }; + + let bin_script_name = item.bin_name.clone().unwrap_or( + PathBuf::from(&item.out) + .file_stem() + .unwrap() + .to_str() + .unwrap() + .to_string(), + ); + #[cfg(target_os = "windows")] + let bin_script_name = PathBuf::from(&bin_script_name) + .with_extension("ps1") .display() .to_string(); - let link_item_to_install = BuildLinkDepItem { - out: artifact_output_path, - ..item.clone() - }; - - let (build, fid) = gen_link_command(&mut graph, &link_item_to_install, moonc_opt); - default.push(fid); - graph.add_build(build)?; + let bin_script_path = install_path.join(bin_script_name); + + if !bin_script_path.exists() { + let artifact_output_path = PathBuf::from(&item.out) + .with_extension(moonc_opt.link_opt.output_format.to_str()) + .display() + .to_string(); + + let runtime = match moonc_opt.link_opt.target_backend { + TargetBackend::Native => "".to_string(), + TargetBackend::Wasm | TargetBackend::WasmGC => "moonrun".to_string(), + TargetBackend::Js => "node".to_string(), + }; + + let bin_script_content = bin_script_content + .replace("$runtime", &runtime) + .replace("$artifact_output_path", &artifact_output_path); + + std::fs::write(&bin_script_path, bin_script_content).with_context(|| { + format!("Failed to write bin script to {:?}", bin_script_path) + })?; + #[cfg(unix)] + { + std::fs::set_permissions( + &bin_script_path, + std::os::unix::fs::PermissionsExt::from_mode(0o755), + ) + .with_context(|| { + format!("Failed to set permissions for {:?}", bin_script_path) + })?; + } + } } } diff --git a/crates/moonbuild/src/pre_build.rs b/crates/moonbuild/src/pre_build.rs index 604ddbdf..d5f3b4b8 100644 --- a/crates/moonbuild/src/pre_build.rs +++ b/crates/moonbuild/src/pre_build.rs @@ -119,6 +119,21 @@ pub fn load_moon_pre_build( .replace(MOD_DIR, &moonbuild_opt.source_dir.display().to_string()) .replace(PKG_DIR, &cwd.display().to_string()); + #[cfg(target_os = "windows")] + let command = { + let maybe_ps1 = command.trim_start().split(" ").next().unwrap(); + let ps1_path = moonbuild_opt + .source_dir + .join(maybe_ps1) + .with_extension("ps1"); + let ps1_path = dunce::canonicalize(ps1_path).unwrap(); + if ps1_path.exists() { + format!("powershell {}", ps1_path.display()) + } else { + command + } + }; + let command = command .replace("$input", &inputs.join(" ")) .replace("$output", &outputs.join(" ")); diff --git a/crates/moonbuild/template/moon_bin_script_template/unix.sh b/crates/moonbuild/template/moon_bin_script_template/unix.sh new file mode 100755 index 00000000..2143d494 --- /dev/null +++ b/crates/moonbuild/template/moon_bin_script_template/unix.sh @@ -0,0 +1,2 @@ +#!/bin/sh +$runtime $artifact_output_path "$@" diff --git a/crates/moonbuild/template/moon_bin_script_template/windows.ps1 b/crates/moonbuild/template/moon_bin_script_template/windows.ps1 new file mode 100755 index 00000000..deed7c39 --- /dev/null +++ b/crates/moonbuild/template/moon_bin_script_template/windows.ps1 @@ -0,0 +1 @@ +$runtime $artifact_output_path $args From 2ff966144d16ef3ca485ef178ec905c7ff612afa Mon Sep 17 00:00:00 2001 From: Young-Flash Date: Wed, 11 Dec 2024 15:15:10 +0800 Subject: [PATCH 3/3] internal: add same name dir dectection for script bin --- crates/moonbuild/src/gen/gen_build.rs | 6 ++++++ crates/moonbuild/src/pre_build.rs | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/crates/moonbuild/src/gen/gen_build.rs b/crates/moonbuild/src/gen/gen_build.rs index d6322842..11c92e15 100644 --- a/crates/moonbuild/src/gen/gen_build.rs +++ b/crates/moonbuild/src/gen/gen_build.rs @@ -505,6 +505,12 @@ pub fn gen_n2_build_state( .to_string(); let bin_script_path = install_path.join(bin_script_name); + if bin_script_path.exists() && bin_script_path.is_dir() { + anyhow::bail!( + "bin install failed, there is a directory {:?} already exists", + bin_script_path + ); + } if !bin_script_path.exists() { let artifact_output_path = PathBuf::from(&item.out) diff --git a/crates/moonbuild/src/pre_build.rs b/crates/moonbuild/src/pre_build.rs index d5f3b4b8..eb12895a 100644 --- a/crates/moonbuild/src/pre_build.rs +++ b/crates/moonbuild/src/pre_build.rs @@ -126,8 +126,8 @@ pub fn load_moon_pre_build( .source_dir .join(maybe_ps1) .with_extension("ps1"); - let ps1_path = dunce::canonicalize(ps1_path).unwrap(); if ps1_path.exists() { + let ps1_path = dunce::canonicalize(ps1_path).unwrap(); format!("powershell {}", ps1_path.display()) } else { command