summaryrefslogtreecommitdiffstats
path: root/src/modules/package.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/modules/package.rs')
-rw-r--r--src/modules/package.rs56
1 files changed, 41 insertions, 15 deletions
diff --git a/src/modules/package.rs b/src/modules/package.rs
index 1f95a7e0a..718ef21ea 100644
--- a/src/modules/package.rs
+++ b/src/modules/package.rs
@@ -54,13 +54,6 @@ fn extract_cargo_version(file_contents: &str) -> Option<String> {
Some(formatted_version)
}
-fn extract_vlang_version(file_contents: &str) -> Option<String> {
- let re = Regex::new(r"(?m)^\s*version\s*:\s*'(?P<version>[^']+)'").unwrap();
- let caps = re.captures(file_contents)?;
- let formatted_version = format_version(&caps["version"]);
- Some(formatted_version)
-}
-
fn extract_package_version(file_contents: &str, display_private: bool) -> Option<String> {
let package_json: json::Value = json::from_str(file_contents).ok()?;
@@ -184,6 +177,23 @@ fn extract_meson_version(file_contents: &str) -> Option<String> {
Some(formatted_version)
}
+fn extract_vmod_version(file_contents: &str) -> Option<String> {
+ let re = Regex::new(r"(?m)^\s*version\s*:\s*'(?P<version>[^']+)'").unwrap();
+ let caps = re.captures(file_contents)?;
+ let formatted_version = format_version(&caps["version"]);
+ Some(formatted_version)
+}
+
+fn extract_vpkg_version(file_contents: &str) -> Option<String> {
+ let vpkg_json: json::Value = json::from_str(file_contents).ok()?;
+ let version = vpkg_json.get("version")?.as_str()?;
+ if version == "null" {
+ return None;
+ }
+ let formatted_version = format_version(&version);
+ Some(formatted_version)
+}
+
fn get_package_version(base_dir: &Path, config: &PackageConfig) -> Option<String> {
if let Ok(cargo_toml) = utils::read_file(base_dir.join("Cargo.toml")) {
extract_cargo_version(&cargo_toml)
@@ -206,7 +216,9 @@ fn get_package_version(base_dir: &Path, config: &PackageConfig) -> Option<String
} else if let Ok(meson_build) = utils::read_file(base_dir.join("meson.build")) {
extract_meson_version(&meson_build)
} else if let Ok(vlang_mod) = utils::read_file(base_dir.join("v.mod")) {
- extract_vlang_version(&vlang_mod)
+ extract_vmod_version(&vlang_mod)
+ } else if let Ok(vlang_vpkg) = utils::read_file(base_dir.join("vpkg.json")) {
+ extract_vpkg_version(&vlang_vpkg)
} else {
None
}
@@ -828,20 +840,34 @@ end";
}
#[test]
- fn test_extract_vlang_version() -> io::Result<()> {
+ fn test_extract_vmod_version() -> io::Result<()> {
let config_name = "v.mod";
- let config_content = "
- Module {
- name: 'starship',
- author: 'matchai',
- version: '1.2.3'
- }";
+ let config_content = "\
+Module {
+ name: 'starship',
+ author: 'matchai',
+ version: '1.2.3'
+}";
let project_dir = create_project_dir()?;
fill_config(&project_dir, config_name, Some(&config_content))?;
expect_output(&project_dir, Some("v1.2.3"), None);
project_dir.close()
}
+ #[test]
+ fn test_extract_vpkg_version() -> io::Result<()> {
+ let config_name = "vpkg.json";
+ let config_content = json::json!({
+ "name": "starship",
+ "version": "0.1.0"
+ })
+ .to_string();
+ let project_dir = create_project_dir()?;
+ fill_config(&project_dir, config_name, Some(&config_content))?;
+ expect_output(&project_dir, Some("v0.1.0"), None);
+ project_dir.close()
+ }
+
fn create_project_dir() -> io::Result<TempDir> {
tempfile::tempdir()
}