mirror of
https://git.proxmox.com/git/perlmod
synced 2025-10-04 18:27:16 +00:00
macro: use CARGO_PKG_NAME instead of reading Cargo.toml
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
This commit is contained in:
parent
c9d79aaea8
commit
9de065545b
@ -21,7 +21,6 @@ anyhow = "1.0"
|
|||||||
proc-macro2 = "1.0"
|
proc-macro2 = "1.0"
|
||||||
quote = "1.0"
|
quote = "1.0"
|
||||||
syn = { version = "1.0", features = [ "full" ] }
|
syn = { version = "1.0", features = [ "full" ] }
|
||||||
toml = "0.5.5"
|
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
perlmod = { path = "../perlmod" }
|
perlmod = { path = "../perlmod" }
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
use std::collections::HashMap;
|
|
||||||
use std::convert::TryFrom;
|
use std::convert::TryFrom;
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::fs::File;
|
|
||||||
use std::path::PathBuf;
|
|
||||||
|
|
||||||
use anyhow::Error;
|
use anyhow::Error;
|
||||||
|
|
||||||
@ -10,8 +7,6 @@ use proc_macro2::{Ident, Span};
|
|||||||
|
|
||||||
use syn::AttributeArgs;
|
use syn::AttributeArgs;
|
||||||
|
|
||||||
use toml::Value;
|
|
||||||
|
|
||||||
use crate::attribs::ModuleAttrs;
|
use crate::attribs::ModuleAttrs;
|
||||||
|
|
||||||
const MODULE_HEAD: &str = r#"
|
const MODULE_HEAD: &str = r#"
|
||||||
@ -138,54 +133,14 @@ impl Package {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn read_cargo_toml(why: Span) -> Result<HashMap<String, Value>, syn::Error> {
|
pub fn get_default_lib_name(why: Span) -> Result<String, syn::Error> {
|
||||||
let manifest_dir = env::var("CARGO_MANIFEST_DIR")
|
env::var("CARGO_PKG_NAME")
|
||||||
.map_err(|err| format_err!(why, "failed to get CARGO_MANIFEST_DIR variable: {}", err))?;
|
.map(|s| s.replace('-', "_"))
|
||||||
let cargo_toml_path = PathBuf::from(manifest_dir).join("Cargo.toml");
|
.map_err(|err| {
|
||||||
|
|
||||||
use std::io::Read;
|
|
||||||
let mut content = String::new();
|
|
||||||
File::open(cargo_toml_path)
|
|
||||||
.map_err(|err| format_err!(why, "failed to open Cargo.toml: {}", err))?
|
|
||||||
.read_to_string(&mut content)
|
|
||||||
.map_err(|err| format_err!(why, "failed to read Cargo.toml: {}", err))?;
|
|
||||||
|
|
||||||
toml::from_str(&content).map_err(|err| format_err!(why, "failed to parse Cargo.toml: {}", err))
|
|
||||||
}
|
|
||||||
|
|
||||||
static mut LIB_NAME: Option<String> = None;
|
|
||||||
pub fn get_default_lib_name(why: Span) -> Result<&'static str, syn::Error> {
|
|
||||||
unsafe {
|
|
||||||
if let Some(name) = &LIB_NAME {
|
|
||||||
return Ok(name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let cargo = read_cargo_toml(why)?;
|
|
||||||
|
|
||||||
let package = cargo
|
|
||||||
.get("package")
|
|
||||||
.ok_or_else(|| format_err!(
|
|
||||||
why,
|
|
||||||
"did not find a [package] section in Cargo.toml, try to specify the library name manually",
|
|
||||||
))?;
|
|
||||||
|
|
||||||
let name = package.get("name").ok_or_else(|| {
|
|
||||||
format_err!(
|
format_err!(
|
||||||
why,
|
why,
|
||||||
"failed to find the package name in Cargo.toml, try to specify the library name manually",
|
"failed to get CARGO_PKG_NAME environment variable: {}",
|
||||||
|
err
|
||||||
)
|
)
|
||||||
})?;
|
})
|
||||||
|
|
||||||
let name = name.as_str().ok_or_else(|| {
|
|
||||||
format_err!(
|
|
||||||
why,
|
|
||||||
"package name in Cargo.toml is not a string, try to specify the library name manually",
|
|
||||||
)
|
|
||||||
})?;
|
|
||||||
|
|
||||||
unsafe {
|
|
||||||
LIB_NAME = Some(name.replace('-', "_"));
|
|
||||||
return Ok(LIB_NAME.as_ref().unwrap());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user