fix(tvix/eval): baseNameOf should not coerce paths into strings
... since this may import them to the store which changes their basename. Fixes b/350. Change-Id: Iabd08ff4d6a424c66d6d7784d7a96b0c078f0a91 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10298 Reviewed-by: tazjin <tazjin@tvl.su> Tested-by: BuildkiteCI Autosubmit: Adam Joseph <adam@westernsemico.com>
This commit is contained in:
parent
8d4aa2c15c
commit
531f0c0c42
1 changed files with 12 additions and 4 deletions
|
@ -134,10 +134,18 @@ mod pure_builtins {
|
||||||
#[builtin("baseNameOf")]
|
#[builtin("baseNameOf")]
|
||||||
async fn builtin_base_name_of(co: GenCo, s: Value) -> Result<Value, ErrorKind> {
|
async fn builtin_base_name_of(co: GenCo, s: Value) -> Result<Value, ErrorKind> {
|
||||||
let span = generators::request_span(&co).await;
|
let span = generators::request_span(&co).await;
|
||||||
let s = s
|
let s = match s {
|
||||||
.coerce_to_string(co, CoercionKind::Weak, span)
|
// it is important that builtins.baseNameOf does not
|
||||||
.await?
|
// coerce paths into strings, since this will turn them
|
||||||
.to_str()?;
|
// into store paths, and `builtins.baseNameOf
|
||||||
|
// ./config.nix` will return a hash-prefixed value like
|
||||||
|
// "hpmyf3vlqg5aadri97xglcvvjbk8xw3g-config.nix"
|
||||||
|
Value::Path(p) => NixString::from(p.to_string_lossy().to_string()),
|
||||||
|
_ => s
|
||||||
|
.coerce_to_string(co, CoercionKind::Weak, span)
|
||||||
|
.await?
|
||||||
|
.to_str()?,
|
||||||
|
};
|
||||||
let result: String = s.rsplit_once('/').map(|(_, x)| x).unwrap_or(&s).into();
|
let result: String = s.rsplit_once('/').map(|(_, x)| x).unwrap_or(&s).into();
|
||||||
Ok(result.into())
|
Ok(result.into())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue