OCamllabs icon Home|Differences with the last checks|Previous runs


Building on x86-bm-c5.sw.ocaml.org

(from ocaml/opam:debian-unstable)
Unable to find image 'ocaml/opam:debian-unstable' locally
debian-unstable: Pulling from ocaml/opam
be391166522c: Pulling fs layer
be391166522c: Verifying Checksum
be391166522c: Download complete
be391166522c: Pull complete
Digest: sha256:f4524a9ad6e8f9deb04c38872c1c68d892f8f847304a90f71b39c260fd7c37ab
Status: Downloaded newer image for ocaml/opam:debian-unstable
2025-01-15 23:00.41 ---> using "0acd5aeaa8f7bc314514d9795d14a7f12ec72a6a5b11c5904350189734c6859b" from cache

/: (user (uid 1000) (gid 1000))

/: (env OPAMPRECISETRACKING 1)

/: (env OPAMUTF8 never)

/: (env OPAMEXTERNALSOLVER builtin-0install)

/: (env OPAMCRITERIA +removed)

/: (env CI true)

/: (env OPAM_HEALTH_CHECK_CI true)

/: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2025-01-15 23:00.41 ---> using "40df4fa4cdfc68a5fa7a326047e82a7adc5df52b8059d4a7b745bdd50aad56e7" from cache

/: (run (network host)
        (shell "rm -rf ~/opam-repository && git clone -q 'https://github.com/ocaml/opam-repository' ~/opam-repository && git -C ~/opam-repository checkout -q 451b1e526ccb27dc66364a851b27fbf7ccfbc2f2"))
2025-01-15 23:00.41 ---> using "52625e8a37d6974e498c46c5b73987a5de23eb753980981e64630dc695fbe3b3" from cache

/: (run (shell "rm -rf ~/.opam && opam init -ya --bare --config ~/.opamrc-sandbox ~/opam-repository"))
Configuring from /home/opam/.opamrc-sandbox, then /home/opam/.opamrc, and finally from built-in defaults.
Checking for available remotes: rsync and local, git.
  - you won't be able to use mercurial repositories unless you install the hg command on your system.
  - you won't be able to use darcs repositories unless you install the darcs command on your system.


<><> Fetching repository information ><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised

User configuration:
  ~/.profile is already up-to-date.
[NOTE] Make sure that ~/.profile is well sourced in your ~/.bashrc.

2025-01-15 23:00.41 ---> using "bf0993b7e440c7679323e43a556b3a337fb81df454233420043ea0f043d5139e" from cache

/: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
        (network host)
        (shell "opam switch create --repositories=default '4.13' '4.13.1'"))

<><> Installing new switch packages <><><><><><><><><><><><><><><><><><><><><><>
Switch invariant: ["ocaml-base-compiler" {= "4.13.1"} | "ocaml-system" {= "4.13.1"}]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ocaml-config.2  (cached)
-> installed base-bigarray.base
-> installed base-threads.base
-> installed base-unix.base
-> installed host-arch-x86_64.1
-> installed host-system-other.1
-> installed ocaml-options-vanilla.1
-> retrieved ocaml-base-compiler.4.13.1  (cached)
-> installed ocaml-base-compiler.4.13.1
-> installed ocaml-config.2
-> installed ocaml.4.13.1
Done.
# To update the current shell environment, run: eval $(opam env --switch=4.13)
2025-01-15 23:00.41 ---> using "cd74acb07d651266571d3d508827b7c732596f3748bd20232d49fd4676b0ff88" from cache

/: (run (network host)
        (shell "opam update --depexts"))
+ /usr/bin/sudo "apt-get" "update"
- Get:1 http://deb.debian.org/debian unstable InRelease [205 kB]
- Get:2 http://deb.debian.org/debian unstable/main amd64 Packages.diff/Index [63.6 kB]
- Get:3 http://deb.debian.org/debian unstable/main amd64 Packages T-2025-01-15-1407.28-F-2025-01-09-1409.48.pdiff [633 kB]
- Get:3 http://deb.debian.org/debian unstable/main amd64 Packages T-2025-01-15-1407.28-F-2025-01-09-1409.48.pdiff [633 kB]
- Fetched 902 kB in 5s (194 kB/s)
- Reading package lists...
- 
2025-01-15 23:00.41 ---> using "9fe72db1a39295a51831b4e1c77786edd5765f48646475aeb1fef1e3ba6ca51d" from cache

/: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
        (network host)
        (shell  "\
               \nopam remove -y \"taglib.0.3.8\"\
               \nopam install -vy \"taglib.0.3.8\"\
               \nres=$?\
               \nif [ $res = 31 ]; then\
               \n    if opam show -f x-ci-accept-failures: \"taglib.0.3.8\" | grep -q '\"debian-unstable\"'; then\
               \n        echo \"This package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\"\
               \n        exit 69\
               \n    fi\
               \nfi\
               \n\
               \n\
               \nexit $res\
               \n"))
[NOTE] taglib.0.3.8 is not installed.

Nothing to do.
The following actions will be performed:
=== install 6 packages
  - install conf-pkg-config   3      [required by conf-taglib]
  - install conf-taglib       1      [required by taglib]
  - install csexp             1.5.2  [required by dune-configurator]
  - install dune              3.17.1 [required by taglib]
  - install dune-configurator 3.17.1 [required by taglib]
  - install taglib            0.3.8

The following system packages will first need to be installed:
    libtag1-dev pkg-config zlib1g-dev

<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>

opam believes some required external dependencies are missing. opam can:
> 1. Run apt-get to install them (may need root/sudo access)
  2. Display the recommended apt-get command and wait while you run it manually (e.g. in another terminal)
  3. Continue anyway, and, upon success, permanently register that this external dependency is present, but not detectable
  4. Abort the installation

[1/2/3/4] 1

+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "libtag1-dev" "pkg-config" "zlib1g-dev"
- Selecting previously unselected package libpkgconf3:amd64.
- (Reading database ... 
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 19812 files and directories currently installed.)
- Preparing to unpack .../0-libpkgconf3_1.8.1-4_amd64.deb ...
- Unpacking libpkgconf3:amd64 (1.8.1-4) ...
- Selecting previously unselected package libtag2:amd64.
- Preparing to unpack .../1-libtag2_2.0.2-2_amd64.deb ...
- Unpacking libtag2:amd64 (2.0.2-2) ...
- Selecting previously unselected package libtag-c2:amd64.
- Preparing to unpack .../2-libtag-c2_2.0.2-2_amd64.deb ...
- Unpacking libtag-c2:amd64 (2.0.2-2) ...
- Selecting previously unselected package zlib1g-dev:amd64.
- Preparing to unpack .../3-zlib1g-dev_1%3a1.3.dfsg+really1.3.1-1+b1_amd64.deb ...
- Unpacking zlib1g-dev:amd64 (1:1.3.dfsg+really1.3.1-1+b1) ...
- Selecting previously unselected package libtag-dev:amd64.
- Preparing to unpack .../4-libtag-dev_2.0.2-2_amd64.deb ...
- Unpacking libtag-dev:amd64 (2.0.2-2) ...
- Selecting previously unselected package libtag-c-dev:amd64.
- Preparing to unpack .../5-libtag-c-dev_2.0.2-2_amd64.deb ...
- Unpacking libtag-c-dev:amd64 (2.0.2-2) ...
- Selecting previously unselected package libtag1-dev.
- Preparing to unpack .../6-libtag1-dev_2.0.2-2_amd64.deb ...
- Unpacking libtag1-dev (2.0.2-2) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../7-pkgconf-bin_1.8.1-4_amd64.deb ...
- Unpacking pkgconf-bin (1.8.1-4) ...
- Selecting previously unselected package pkgconf:amd64.
- Preparing to unpack .../8-pkgconf_1.8.1-4_amd64.deb ...
- Unpacking pkgconf:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkg-config:amd64.
- Preparing to unpack .../9-pkg-config_1.8.1-4_amd64.deb ...
- Unpacking pkg-config:amd64 (1.8.1-4) ...
- Setting up libtag2:amd64 (2.0.2-2) ...
- Setting up libpkgconf3:amd64 (1.8.1-4) ...
- Setting up libtag-c2:amd64 (2.0.2-2) ...
- Setting up pkgconf-bin (1.8.1-4) ...
- Setting up zlib1g-dev:amd64 (1:1.3.dfsg+really1.3.1-1+b1) ...
- Setting up pkgconf:amd64 (1.8.1-4) ...
- Setting up pkg-config:amd64 (1.8.1-4) ...
- Setting up libtag-c-dev:amd64 (2.0.2-2) ...
- Setting up libtag-dev:amd64 (2.0.2-2) ...
- Setting up libtag1-dev (2.0.2-2) ...
- Processing triggers for libc-bin (2.40-5) ...

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  3/17: [csexp.1.5.2: extract]
Processing  4/17: [csexp.1.5.2: extract] [dune.3.17.1, dune-configurator.3.17.1: extract]
Processing  5/17: [csexp.1.5.2: extract] [dune.3.17.1, dune-configurator.3.17.1: extract] [taglib.0.3.8: extract]
Processing  6/17: [csexp.1.5.2: extract] [dune.3.17.1, dune-configurator.3.17.1: extract] [taglib.0.3.8: extract] [conf-pkg-config: pkg-config]
-> retrieved csexp.1.5.2  (cached)
Processing  6/17: [dune.3.17.1, dune-configurator.3.17.1: extract] [taglib.0.3.8: extract] [conf-pkg-config: pkg-config]
-> retrieved taglib.0.3.8  (cached)
Processing  6/17: [dune.3.17.1, dune-configurator.3.17.1: extract] [conf-pkg-config: pkg-config]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "pkg-config" "--help" (CWD=/home/opam/.opam/4.13/.opam-switch/build/conf-pkg-config.3)
- usage: pkgconf [OPTIONS] [LIBRARIES]
- 
- basic options:
- 
-   --help                            this message
-   --about                           print pkgconf version and license to stdout
-   --version                         print supported pkg-config version to stdout
-   --atleast-pkgconfig-version       check whether or not pkgconf is compatible
-                                     with a specified pkg-config version
-   --errors-to-stdout                print all errors on stdout instead of stderr
-   --print-errors                    ensure all errors are printed
-   --short-errors                    be less verbose about some errors
-   --silence-errors                  explicitly be silent about errors
-   --list-all                        list all known packages
-   --list-package-names              list all known package names
-   --simulate                        simulate walking the calculated dependency graph
-   --no-cache                        do not cache already seen packages when
-                                     walking the dependency graph
-   --log-file=filename               write an audit log to a specified file
-   --with-path=path                  adds a directory to the search path
-   --define-prefix                   override the prefix variable with one that is guessed based on
-                                     the location of the .pc file
-   --dont-define-prefix              do not override the prefix variable under any circumstances
-   --prefix-variable=varname         sets the name of the variable that pkgconf considers
-                                     to be the package prefix
-   --relocate=path                   relocates a path and exits (mostly for testsuite)
-   --dont-relocate-paths             disables path relocation support
- 
- cross-compilation personality support:
- 
-   --personality=triplet|filename    sets the personality to 'triplet' or a file named 'filename'
-   --dump-personality                dumps details concerning selected personality
- 
- checking specific pkg-config database entries:
- 
-   --atleast-version                 require a specific version of a module
-   --exact-version                   require an exact version of a module
-   --max-version                     require a maximum version of a module
-   --exists                          check whether or not a module exists
-   --uninstalled                     check whether or not an uninstalled module will be used
-   --no-uninstalled                  never use uninstalled modules when satisfying dependencies
-   --no-provides                     do not use 'provides' rules to resolve dependencies
-   --maximum-traverse-depth          maximum allowed depth for dependency graph
-   --static                          be more aggressive when computing dependency graph
-                                     (for static linking)
-   --shared                          use a simplified dependency graph (usually default)
-   --pure                            optimize a static dependency graph as if it were a normal
-                                     dependency graph
-   --env-only                        look only for package entries in PKG_CONFIG_PATH
-   --ignore-conflicts                ignore 'conflicts' rules in modules
-   --validate                        validate specific .pc files for correctness
- 
- querying specific pkg-config database fields:
- 
-   --define-variable=varname=value   define variable 'varname' as 'value'
-   --variable=varname                print specified variable entry to stdout
-   --cflags                          print required CFLAGS to stdout
-   --cflags-only-I                   print required include-dir CFLAGS to stdout
-   --cflags-only-other               print required non-include-dir CFLAGS to stdout
-   --libs                            print required linker flags to stdout
-   --libs-only-L                     print required LDPATH linker flags to stdout
-   --libs-only-l                     print required LIBNAME linker flags to stdout
-   --libs-only-other                 print required other linker flags to stdout
-   --print-requires                  print required dependency frameworks to stdout
-   --print-requires-private          print required dependency frameworks for static
-                                     linking to stdout
-   --print-provides                  print provided dependencies to stdout
-   --print-variables                 print all known variables in module to stdout
-   --digraph                         print entire dependency graph in graphviz 'dot' format
-   --keep-system-cflags              keep -I/usr/include entries in cflags output
-   --keep-system-libs                keep -L/lib:/lib/i386-linux-gnu:/lib/x86_64-linux-gnu:/lib/x86_64-linux-gnux32:/lib32:/libx32:/usr/lib:/usr/lib/i386-linux-gnu:/usr/lib/x86_64-linux-gnu:/usr/lib/x86_64-linux-gnux32:/usr/lib32:/usr/libx32 entries in libs output
-   --path                            show the exact filenames for any matching .pc files
-   --modversion                      print the specified module's version to stdout
-   --internal-cflags                 do not filter 'internal' cflags from output
- 
- filtering output:
- 
-   --msvc-syntax                     print translatable fragments in MSVC syntax
-   --fragment-filter=types           filter output fragments to the specified types
- 
- report bugs to <https://github.com/pkgconf/pkgconf/issues/new>.
-> compiled  conf-pkg-config.3
Processing  6/17: [dune.3.17.1, dune-configurator.3.17.1: extract]
-> installed conf-pkg-config.3
Processing  7/17: [dune.3.17.1, dune-configurator.3.17.1: extract]
Processing  8/17: [dune.3.17.1, dune-configurator.3.17.1: extract] [conf-taglib: pkg-config taglib]
-> retrieved dune.3.17.1, dune-configurator.3.17.1  (cached)
Processing  8/17: [conf-taglib: pkg-config taglib]
Processing  9/17: [conf-taglib: pkg-config taglib] [dune: ocaml 31]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "pkg-config" "--exists" "taglib" (CWD=/home/opam/.opam/4.13/.opam-switch/build/conf-taglib.1)
-> compiled  conf-taglib.1
Processing  9/17: [dune: ocaml 31]
-> installed conf-taglib.1
Processing 10/17: [dune: ocaml 31]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "ocaml" "boot/bootstrap.ml" "-j" "31" (CWD=/home/opam/.opam/4.13/.opam-switch/build/dune.3.17.1)
- ocamlc -output-complete-exe -w -24 -g -o .duneboot.exe -I boot unix.cma boot/libs.ml boot/duneboot.ml
- ./.duneboot.exe -j 31
- 

Processing 10/17: [dune: ./_boot/dune.exe build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "./_boot/dune.exe" "build" "dune.install" "--release" "--profile" "dune-bootstrap" "-j" "31" (CWD=/home/opam/.opam/4.13/.opam-switch/build/dune.3.17.1)
-> compiled  dune.3.17.1
-> installed dune.3.17.1
Processing 12/17: [csexp: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "csexp" "-j" "31" "@install" (CWD=/home/opam/.opam/4.13/.opam-switch/build/csexp.1.5.2)
-> compiled  csexp.1.5.2
-> installed csexp.1.5.2
Processing 14/17: [dune-configurator: rm]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "rm" "-rf" "vendor/csexp" (CWD=/home/opam/.opam/4.13/.opam-switch/build/dune-configurator.3.17.1)
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "rm" "-rf" "vendor/pp" (CWD=/home/opam/.opam/4.13/.opam-switch/build/dune-configurator.3.17.1)
Processing 14/17: [dune-configurator: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "dune-configurator" "-j" "31" "@install" (CWD=/home/opam/.opam/4.13/.opam-switch/build/dune-configurator.3.17.1)
-> compiled  dune-configurator.3.17.1
-> installed dune-configurator.3.17.1
Processing 16/17: [taglib: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "taglib" "-j" "31" "@install" (CWD=/home/opam/.opam/4.13/.opam-switch/build/taglib.0.3.8)
[ERROR] The compilation of taglib.0.3.8 failed at "dune build -p taglib -j 31 @install".

#=== ERROR while compiling taglib.0.3.8 =======================================#
# context              2.4.0~alpha1~dev | linux/x86_64 | ocaml-base-compiler.4.13.1 | file:///home/opam/opam-repository
# path                 ~/.opam/4.13/.opam-switch/build/taglib.0.3.8
# command              ~/.opam/opam-init/hooks/sandbox.sh build dune build -p taglib -j 31 @install
# exit-code            1
# env-file             ~/.opam/log/taglib-8-10d77c.env
# output-file          ~/.opam/log/taglib-8-10d77c.out
### output ###
# File "src/dune", line 8, characters 9-21:
# 8 |   (names taglib_stubs)
#              ^^^^^^^^^^^^
# (cd _build/default/src && /usr/bin/gcc -fPIC -I/usr/include/taglib -g -I /home/opam/.opam/4.13/lib/ocaml -o taglib_stubs.o -c taglib_stubs.cc)
# taglib_stubs.cc: In function 'value caml_taglib_file_new(value, value)':
# taglib_stubs.cc:217:18: error: 'create' is not a member of 'TagLib::FileRef'
#   217 |     f = FileRef::create(filename);
#       |                  ^~~~~~
# taglib_stubs.cc: In function 'value caml_taglib_audioproperties_get_int(value, value)':
# taglib_stubs.cc:484:23: warning: 'virtual int TagLib::AudioProperties::length() const' is deprecated [-Wdeprecated-declarations]
#   484 |     tmp = prop->length();
#       |           ~~~~~~~~~~~~^~
# In file included from /usr/include/taglib/fileref.h:33,
#                  from taglib_stubs.cc:45:
# /usr/include/taglib/audioproperties.h:82:17: note: declared here
#    82 |     virtual int length() const;
#       |                 ^~~~~~
# taglib_stubs.cc: In function 'value caml_taglib_id3v2_parse_tag(value, value)':
# taglib_stubs.cc:553:11: error: 'uint' is not a member of 'TagLib'; did you mean 'uint'?
#   553 |   TagLib::uint size = ID3v2::Header::size();
#       |           ^~~~
# In file included from /usr/include/stdlib.h:514,
#                  from /usr/include/c++/14/cstdlib:79,
#                  from /usr/include/c++/14/stdlib.h:36,
#                  from taglib_stubs.cc:43:
# /usr/include/x86_64-linux-gnu/sys/types.h:150:22: note: 'uint' declared here
#   150 | typedef unsigned int uint;
#       |                      ^~~~
# taglib_stubs.cc:555:31: error: 'size' was not declared in this scope; did you mean 'std::size'?
#   555 |   tag->doParse(ByteVector(s + size, caml_string_length(h) - size));
#       |                               ^~~~
#       |                               std::size
# In file included from /usr/include/c++/14/vector:69,
#                  from /usr/include/taglib/tbytevector.h:30,
#                  from /usr/include/taglib/tfile.h:29,
#                  from /usr/include/taglib/fileref.h:29:
# /usr/include/c++/14/bits/range_access.h:272:5: note: 'std::size' declared here
#   272 |     size(const _Tp (&)[_Nm]) noexcept
#       |     ^~~~

- File "src/dune", line 8, characters 9-21:
- 8 |   (names taglib_stubs)
-              ^^^^^^^^^^^^
- (cd _build/default/src && /usr/bin/gcc -fPIC -I/usr/include/taglib -g -I /home/opam/.opam/4.13/lib/ocaml -o taglib_stubs.o -c taglib_stubs.cc)
- taglib_stubs.cc: In function 'value caml_taglib_file_new(value, value)':
- taglib_stubs.cc:217:18: error: 'create' is not a member of 'TagLib::FileRef'
-   217 |     f = FileRef::create(filename);
-       |                  ^~~~~~
- taglib_stubs.cc: In function 'value caml_taglib_audioproperties_get_int(value, value)':
- taglib_stubs.cc:484:23: warning: 'virtual int TagLib::AudioProperties::length() const' is deprecated [-Wdeprecated-declarations]
-   484 |     tmp = prop->length();
-       |           ~~~~~~~~~~~~^~
- In file included from /usr/include/taglib/fileref.h:33,
-                  from taglib_stubs.cc:45:
- /usr/include/taglib/audioproperties.h:82:17: note: declared here
-    82 |     virtual int length() const;
-       |                 ^~~~~~
- taglib_stubs.cc: In function 'value caml_taglib_id3v2_parse_tag(value, value)':
- taglib_stubs.cc:553:11: error: 'uint' is not a member of 'TagLib'; did you mean 'uint'?
-   553 |   TagLib::uint size = ID3v2::Header::size();
-       |           ^~~~
- In file included from /usr/include/stdlib.h:514,
-                  from /usr/include/c++/14/cstdlib:79,
-                  from /usr/include/c++/14/stdlib.h:36,
-                  from taglib_stubs.cc:43:
- /usr/include/x86_64-linux-gnu/sys/types.h:150:22: note: 'uint' declared here
-   150 | typedef unsigned int uint;
-       |                      ^~~~
- taglib_stubs.cc:555:31: error: 'size' was not declared in this scope; did you mean 'std::size'?
-   555 |   tag->doParse(ByteVector(s + size, caml_string_length(h) - size));
-       |                               ^~~~
-       |                               std::size
- In file included from /usr/include/c++/14/vector:69,
-                  from /usr/include/taglib/tbytevector.h:30,
-                  from /usr/include/taglib/tfile.h:29,
-                  from /usr/include/taglib/fileref.h:29:
- /usr/include/c++/14/bits/range_access.h:272:5: note: 'std::size' declared here
-   272 |     size(const _Tp (&)[_Nm]) noexcept
-       |     ^~~~


<><> Error report <><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><>
+- The following actions failed
| - build taglib 0.3.8
+- 
+- The following changes have been performed
| - install conf-pkg-config   3
| - install conf-taglib       1
| - install csexp             1.5.2
| - install dune              3.17.1
| - install dune-configurator 3.17.1
+- 
# To update the current shell environment, run: eval $(opam env)

The former state can be restored with:
    /usr/bin/opam switch import "/home/opam/.opam/4.13/.opam-switch/backup/state-20250115230043.export"
'opam install -vy taglib.0.3.8' failed.
"/usr/bin/env" "bash" "-c" "
opam remove -y "taglib.0.3.8"
opam install -vy "taglib.0.3.8"
res=$?
if [ $res = 31 ]; then
    if opam show -f x-ci-accept-failures: "taglib.0.3.8" | grep -q '"debian-unstable"'; then
        echo "This package failed and has been disabled for CI using the 'x-ci-accept-failures' field."
        exit 69
    fi
fi


exit $res
" failed with exit status 31
Failed: Build failed