1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
use crate::DenoLanguage;
use core::str;
use log::debug;
use proto_core::{
async_trait, create_version_manifest_from_tags, is_offline, is_semantic_version, load_git_tags,
remove_v_prefix, Describable, ProtoError, Resolvable, VersionManifest,
};
#[async_trait]
impl Resolvable<'_> for DenoLanguage {
fn get_resolved_version(&self) -> &str {
match self.version.as_ref() {
Some(version) => version,
None => "latest",
}
}
async fn load_version_manifest(&self) -> Result<VersionManifest, ProtoError> {
let tags = load_git_tags("https://github.com/denoland/deno")
.await?
.iter()
.filter(|t| t.starts_with('v'))
.map(|t| remove_v_prefix(t))
.collect::<Vec<_>>();
let manifest = create_version_manifest_from_tags(tags);
Ok(manifest)
}
async fn resolve_version(&mut self, initial_version: &str) -> Result<String, ProtoError> {
if let Some(version) = &self.version {
return Ok(version.to_owned());
}
let initial_version = remove_v_prefix(initial_version).to_lowercase();
if is_semantic_version(&initial_version) && is_offline() {
self.set_version(&initial_version);
return Ok(initial_version);
}
debug!(
target: self.get_log_target(),
"Resolving a semantic version for \"{}\"",
initial_version,
);
let manifest = self.load_version_manifest().await?;
let candidate = if initial_version == "latest" {
manifest.find_version_from_alias(&initial_version)?
} else {
manifest.find_version(&initial_version)?
};
debug!(target: self.get_log_target(), "Resolved to {}", candidate);
self.set_version(candidate);
Ok(candidate.to_owned())
}
fn set_version(&mut self, version: &str) {
self.version = Some(version.to_owned());
}
}