fix(swift): parsing swift version (#1913)
* fix parse swift version for swift-for-tensorflow * add test for parsing swift version Co-authored-by: Masashi Aso <maashi.apple.japan@icloud.com>
This commit is contained in:
parent
87424d2eaf
commit
eb4e59d9ea
|
@ -53,11 +53,12 @@ pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_swift_version(swift_version: &str) -> Option<String> {
|
fn parse_swift_version(swift_version: &str) -> Option<String> {
|
||||||
let version = swift_version
|
// split into ["Apple", "Swift", "version", "5.2.2", ...] or
|
||||||
// split into ["Apple", "Swift", "version", "5.2.2", ...]
|
// ["Swift", "version", "5.3-dev", ...]
|
||||||
.split_whitespace()
|
let mut splited = swift_version.split_whitespace();
|
||||||
// return "5.2.2"
|
let _ = splited.position(|t| t == "version")?;
|
||||||
.nth(3)?;
|
// return "5.2.2" or "5.3-dev"
|
||||||
|
let version = splited.next()?;
|
||||||
|
|
||||||
Some(format!("v{}", version))
|
Some(format!("v{}", version))
|
||||||
}
|
}
|
||||||
|
@ -76,6 +77,12 @@ mod tests {
|
||||||
assert_eq!(parse_swift_version(input), Some(String::from("v5.2.2")));
|
assert_eq!(parse_swift_version(input), Some(String::from("v5.2.2")));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_parse_swift_version_without_org_name() {
|
||||||
|
let input = "Swift version 5.3-dev (LLVM ..., Swift ...)";
|
||||||
|
assert_eq!(parse_swift_version(input), Some(String::from("v5.3-dev")));
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn folder_without_swift_files() -> io::Result<()> {
|
fn folder_without_swift_files() -> io::Result<()> {
|
||||||
let dir = tempfile::tempdir()?;
|
let dir = tempfile::tempdir()?;
|
||||||
|
|
Loading…
Reference in New Issue