summaryrefslogtreecommitdiff
path: root/src/python.rs
diff options
context:
space:
mode:
authorLars Wirzenius <liw@liw.fi>2021-04-22 05:43:18 +0000
committerLars Wirzenius <liw@liw.fi>2021-04-22 05:43:18 +0000
commit4427fe12410f911a9c8f18ea7b3c9643c88f6d5f (patch)
treee05affad9e645047bddee6a93ca69e11445f50fa /src/python.rs
parent1600a727446867029451df6f8a181b5a07709efb (diff)
parent24574aef2299925c10eeb9d20a942f36d1d806d4 (diff)
downloadbumper-rs-4427fe12410f911a9c8f18ea7b3c9643c88f6d5f.tar.gz
Merge branch 'tagname-take2' into 'main'
make git tag name be configurable via a template Closes #1 See merge request larswirzenius/bumper!19
Diffstat (limited to 'src/python.rs')
-rw-r--r--src/python.rs22
1 files changed, 21 insertions, 1 deletions
diff --git a/src/python.rs b/src/python.rs
index 4cc043e..28c0aec 100644
--- a/src/python.rs
+++ b/src/python.rs
@@ -2,8 +2,10 @@ use crate::errors::BumperError;
use glob::glob;
use log::{debug, info};
use std::path::{Path, PathBuf};
+use std::process::Command;
pub struct Python {
+ dirname: PathBuf,
version_pys: Vec<PathBuf>,
}
@@ -17,13 +19,31 @@ impl Python {
debug!("no version.py files in {}", dirname.display());
Err(BumperError::NoVersionPy(dirname.to_path_buf()))
} else {
- Ok(Self { version_pys: files })
+ Ok(Self {
+ dirname: dirname.to_path_buf(),
+ version_pys: files,
+ })
}
} else {
Err(BumperError::UnknownProjectKind(dirname.to_path_buf()))
}
}
+ pub fn name(&mut self) -> Result<String, BumperError> {
+ let output = Command::new("./setup.py")
+ .arg("--name")
+ .current_dir(&self.dirname)
+ .output()
+ .map_err(|err| BumperError::Setupnvoke(self.dirname.to_path_buf(), err))?;
+ if output.status.success() {
+ let name = String::from_utf8_lossy(&output.stdout).into_owned();
+ Ok(name.trim_end().to_string())
+ } else {
+ let stderr = String::from_utf8_lossy(&output.stderr).into_owned();
+ Err(BumperError::Setup(self.dirname.to_path_buf(), stderr))
+ }
+ }
+
pub fn set_version(&mut self, version: &str) -> Result<String, BumperError> {
for filename in self.version_pys.iter() {
info!("writing Python version to {}", filename.display());