aboutsummaryrefslogtreecommitdiff
path: root/libbpkg
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2022-01-18 14:03:20 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2022-01-18 14:28:42 +0300
commit384ee407d3b83333c6c9c9902dcd952e191e4ba1 (patch)
treef02606084ea38805dace4d8a2f2a1e158e20aef3 /libbpkg
parent62bd2494177be466dc6c1f418db328e99bae53ec (diff)
Add temporary support for requirements similar to '? cli'
Diffstat (limited to 'libbpkg')
-rw-r--r--libbpkg/manifest.cxx19
1 files changed, 18 insertions, 1 deletions
diff --git a/libbpkg/manifest.cxx b/libbpkg/manifest.cxx
index 6a5ce25..a71e1ab 100644
--- a/libbpkg/manifest.cxx
+++ b/libbpkg/manifest.cxx
@@ -1989,9 +1989,26 @@ namespace bpkg
if (requirements_ && first && tt == type::question)
{
r.emplace_back (dependency ());
- r.enable = lexer_->peek_char () == '(' ? parse_eval () : string ();
+
+ bool eval (lexer_->peek_char () == '(');
+ r.enable = eval ? parse_eval () : string ();
next (t, tt);
+
+ // @@ TMP Treat requirements similar to `? cli` as `cli ?` until
+ // toolchain 0.15.0 and libodb-mssql 2.5.0-b.22 are both released.
+ //
+ // NOTE: don't forget to drop the temporary test in
+ // tests/manifest/testscript when dropping this workaround.
+ //
+ if (!eval && tt == type::word)
+ try
+ {
+ r.back ().name = package_name (move (t.value));
+ next (t, tt);
+ }
+ catch (const invalid_argument&) {}
+
return r;
}