aboutsummaryrefslogtreecommitdiff
path: root/mingling_core/src/builds
diff options
context:
space:
mode:
author魏曹先生 <1992414357@qq.com>2026-06-29 15:31:58 +0800
committer魏曹先生 <1992414357@qq.com>2026-06-29 15:31:58 +0800
commit5b1593afa467df256fcd7076967d305bebbb21ee (patch)
tree5740576ecc364ed0064daff55c86efa2a3aed738 /mingling_core/src/builds
parent709b672731bcc1b68209cadc38e0de78d7c28c03 (diff)
refactor(core): move pathf module under builds and rename to buildHEADunreleasedmain
Migrate `mingling_core::pathf` into `mingling_core::builds::pathf` and re-export from `mingling::build`. Update all references from `mingling::builds` and `mingling::pathf` to `mingling::build`.
Diffstat (limited to 'mingling_core/src/builds')
-rw-r--r--mingling_core/src/builds/pathf.rs43
1 files changed, 43 insertions, 0 deletions
diff --git a/mingling_core/src/builds/pathf.rs b/mingling_core/src/builds/pathf.rs
new file mode 100644
index 0000000..d8d4698
--- /dev/null
+++ b/mingling_core/src/builds/pathf.rs
@@ -0,0 +1,43 @@
+pub use mingling_pathf::config::*;
+pub use mingling_pathf::module_pathf::*;
+pub use mingling_pathf::pattern_analyzer::*;
+pub use mingling_pathf::patterns::*;
+
+use std::path::Path;
+
+/// Wraps `analyze_and_build_type_mapping_for` with config derived from
+/// the crate's feature flags (e.g., `dispatch_tree`).
+pub fn analyze_and_build_type_mapping_for(
+ crate_dir: &Path,
+ output_dir: &Path,
+) -> Result<(), crate::error::MinglingPathfinderError> {
+ let config = mingling_pathf::config::PathfinderConfig {
+ use_dispatch_tree: cfg!(feature = "dispatch_tree"),
+ };
+ mingling_pathf::analyze_and_build_type_mapping_for(crate_dir, output_dir, &config)
+}
+
+/// Wraps `analyze_and_build_type_mapping` (build.rs convenience) with config.
+pub fn analyze_and_build_type_mapping() -> Result<(), crate::error::MinglingPathfinderError> {
+ let config = mingling_pathf::config::PathfinderConfig {
+ use_dispatch_tree: cfg!(feature = "dispatch_tree"),
+ };
+ let crate_dir =
+ std::env::current_dir().map_err(crate::error::MinglingPathfinderError::IoError)?;
+ let crate_name = std::env::var("CARGO_PKG_NAME").map_err(|_| {
+ crate::error::MinglingPathfinderError::IoError(std::io::Error::new(
+ std::io::ErrorKind::NotFound,
+ "CARGO_PKG_NAME not set",
+ ))
+ })?;
+ let out_dir = std::env::var("OUT_DIR").map_err(|_| {
+ crate::error::MinglingPathfinderError::IoError(std::io::Error::new(
+ std::io::ErrorKind::NotFound,
+ "OUT_DIR not set",
+ ))
+ })?;
+ let output_dir = Path::new(&out_dir).join(&crate_name);
+ mingling_pathf::analyze_and_build_type_mapping_for(&crate_dir, &output_dir, &config)?;
+ println!("cargo:rerun-if-changed=src/");
+ Ok(())
+}