Test ran at 2025-09-26 12:27:20.226143+00:00 SOLUTION: image_io=20240725.0.0: Output in BMP,PPM,QOI;input in BMP,GIF,JPG,PNG,PNM,QOI,TGA Origin: commit e3fcdc57ed2f868e3ad21aeb3330d23c5ec3dbe5 from https://github.com/bracke/Image_IO.git Properties: Author: Jeff Carter Build Switches: Description: Output in BMP,PPM,QOI;input in BMP,GIF,JPG,PNG,PNM,QOI,TGA License: BSD-3-Clause Long_Description: # Image_IO Output in BMP, PNG, PPM, and QOI formats; input in BMP, GIF, JPG, PNG, PNM, QOI, and TGA formats Package Image_IO.Operations provides the ability to input and output images. PNG is a lossless compressed format that is widely supported. Uncompressed BMP is a universal format that is very large. PPM is intended to be a set of portable formats, but lacks support by default on some platforms. QOI is a lossless compressed format, but not widely supported. Write_P3 uses [PragmARC.Text_IO](https://github.com/jrcarter/PragmARC/blob/Ada-12/pragmarc-text_io.ads) to obtain uniform line terminators across platforms. This can be easily changed to Ada.Text_IO if the line terminators are not a concern. Write_PNG uses [Z_Compression](https://github.com/jrcarter/Z_Compression) and [CRC-32](https://github.com/jrcarter/CRC-32). Read is a wrapper around [Generic Image Decoder (GID)](https://github.com/zertovitch/gid) for the most common use: reading an image from a file. GID may be used to decode images from other sources, but that generality makes it complex to use. Read ignores transparency (Alpha channel) and only reads the first frame of an animation. Pure_RGB is a demo program that reads an image using Read, modifies it to change all color components to the closest of 0 or 255, and outputs the result using Write_PNG. It is invoked with pure_rgb The output name is the input name with ".png" appended. Pure_RGB does no error handling; if the input file name is omitted, doesn't exist, or is not a supported image format, the program will terminate with an unhandled exception. Image_IO and Pure_RGB have been compiled and tested with GNAT 12.3.0 on Linux and ObjectAda 10.5U7 on Windows. Maintainer: Bent Bracke Maintainers_Logins: bracke Name: image_io Tag: image Tag: io Tag: bmp Tag: ppm Tag: qoi Tag: gif Tag: jpg Tag: png Tag: pnm Tag: tga Version: 20240725.0.0 Website: https://github.com/bracke/Image_IO Dependencies (direct): crc_32^20240725.0.0 gid^13.0.0 gnat<13.0 | >=13.3 pragmarc^20240323.0.0 z_compression^20240724.0.0 Dependencies (solution): crc_32=20240725.0.0 gid=13.0.1 gnat=10.3.2 (gnat_native) pragmarc=20240323.0.0 z_compression=20240724.0.0 Dependencies (graph): crc_32=20240725.0.0 --> gnat=10.3.2 (gnat_native) (<13.0 | >=13.3) image_io=20240725.0.0 --> crc_32=20240725.0.0 (^20240725.0.0) image_io=20240725.0.0 --> gid=13.0.1 (^13.0.0) image_io=20240725.0.0 --> gnat=10.3.2 (gnat_native) (<13.0 | >=13.3) image_io=20240725.0.0 --> pragmarc=20240323.0.0 (^20240323.0.0) image_io=20240725.0.0 --> z_compression=20240724.0.0 (^20240724.0.0) pragmarc=20240323.0.0 --> gnat=10.3.2 (gnat_native) (<13.0 | >=13.3) z_compression=20240724.0.0 --> gnat=10.3.2 (gnat_native) (<13.0 | >=13.3) LOG: [alr test] Testing image_io=20240725.0.0 [alr test] Spawning retrieval for remote crate: alr -d -n get image_io=20240725.0.0 Note: Deploying image_io=20240725.0.0... Note: Deploying gid=13.0.1... ######################################################################## 100.0% ######################################################################## 100.0% ######################################################################## 100.0% #=#=# ######################################################################## 100.0% ##=#=# ##-=#=-# # #=O#- # ################################################################### 93.3% ######################################################################## 100.0% Note: Deploying crc_32=20240725.0.0... Note: Deploying pragmarc=20240323.0.0... Note: Deploying z_compression=20240724.0.0... image_io=20240725.0.0 successfully retrieved. Dependencies were solved as follows: + crc_32 20240725.0.0 (new) + gid 13.0.1 (new) +b gnat 10.3.2 (new,gnat_native,binary) + pragmarc 20240323.0.0 (new) + z_compression 20240724.0.0 (new) [alr test] Spawning default test for remote crate: alr -d -n build --release -- -cargs:Ada -gnatwn Note: Building gid=13.0.1/gid.gpr... Setup [mkdir] object directory for project GID Compile [Ada] to_png.adb [Ada] to_bmp.adb [Ada] mini.adb [Ada] all_rgb.adb [Ada] benchmark.adb [Ada] color_avg.adb [Ada] comp_img.adb [Ada] is_opaque.adb [Ada] recurve.adb [Ada] steg.adb [Ada] dumb_png.adb [Ada] gid.adb [Ada] color_distances.adb [Ada] color_statistics.adb [Ada] comp_img_fct.adb [Ada] fast_io.adb [Ada] gid-decoding_bmp.adb fast_io.ads:11:64: (style) trailing spaces not permitted [Ada] gid-decoding_gif.adb [Ada] gid-decoding_jpg.adb [Ada] gid-decoding_png.adb [Ada] gid-decoding_pnm.adb [Ada] gid-decoding_qoi.adb [Ada] gid-decoding_tga.adb [Ada] gid-headers.adb [Ada] gid-buffering.adb [Ada] gid-color_tables.adb [Ada] gid-decoding_png-huffman.adb Bind [gprbind] to_png.bexch [gprbind] to_bmp.bexch [gprbind] mini.bexch [Ada] to_png.ali [gprbind] all_rgb.bexch [Ada] to_bmp.ali [Ada] all_rgb.ali [Ada] mini.ali [gprbind] benchmark.bexch [Ada] benchmark.ali [gprbind] color_avg.bexch [gprbind] comp_img.bexch [Ada] color_avg.ali [Ada] comp_img.ali [gprbind] is_opaque.bexch [Ada] is_opaque.ali [gprbind] recurve.bexch [gprbind] steg.bexch [Ada] recurve.ali [Ada] steg.ali Link [link] to_png.adb [link] to_bmp.adb [link] mini.adb [link] all_rgb.adb [link] benchmark.adb [link] color_avg.adb [link] comp_img.adb [link] is_opaque.adb [link] recurve.adb [link] steg.adb Note: Building image_io=20240725.0.0/image_io.gpr... Setup [mkdir] object directory for project Crc_32 [mkdir] library directory for project Crc_32 [mkdir] object directory for project PragmARC [mkdir] library directory for project PragmARC [mkdir] object directory for project Z_Compression [mkdir] library directory for project Z_Compression [mkdir] object directory for project Image_IO [mkdir] library directory for project Image_IO Compile [Ada] z_compression_config.ads [Ada] z_compression.adb [Ada] z_compression-lz77.adb [Ada] z_compression-length_limited_huffman_code_lengths.adb [Ada] pragmarc_config.ads [Ada] pragmarc.ads [Ada] pragmarc-wrapping.ads [Ada] pragmarc-word_input.adb [Ada] pragmarc-unbounded_numbers.ads [Ada] pragmarc-unbounded_numbers-rationals.adb [Ada] pragmarc-unbounded_numbers-integers.adb [Ada] pragmarc-title_comparisons.adb [Ada] pragmarc-three_way.adb [Ada] pragmarc-text_io.adb [Ada] pragmarc-task_communication.ads [Ada] pragmarc-task_communication-transporters.adb [Ada] pragmarc-task_communication-monitors.adb [Ada] pragmarc-task_communication-forwarders.adb [Ada] pragmarc-sorting.ads [Ada] pragmarc-sorting-radix.adb [Ada] pragmarc-sorting-quick.adb [Ada] pragmarc-sorting-insertion.adb [Ada] pragmarc-sorting-heap.adb [Ada] pragmarc-safety.ads [Ada] pragmarc-safety-suspension_objects.adb [Ada] pragmarc-safety-semaphores.adb [Ada] pragmarc-safety-pointers.adb [Ada] pragmarc-rem_nn_wrapper.adb [Ada] pragmarc-reflection.ads [Ada] pragmarc-rational_postfix_calculator.adb [Ada] pragmarc-randomness.ads [Ada] pragmarc-randomness-universal.adb [Ada] pragmarc-randomness-u32_ranges.adb [Ada] pragmarc-randomness-threefry.adb [Ada] pragmarc-randomness-real_values.ads [Ada] pragmarc-randomness-real_ranges.adb [Ada] pragmarc-randomness-kiss.adb [Ada] pragmarc-randomness-isaac.adb [Ada] pragmarc-randomness-combined.adb [Ada] pragmarc-protected_option.adb [Ada] pragmarc-postfix_calculator.adb [Ada] pragmarc-persistent_skip_list_unbounded.adb [Ada] pragmarc-permutations.adb [Ada] pragmarc-mixed_case.adb [Ada] pragmarc-min_max.ads [Ada] pragmarc-menu_handler.adb [Ada] pragmarc-math.adb [Ada] pragmarc-matching.ads [Ada] pragmarc-matching-regular_expression.adb [Ada] pragmarc-matching-quick_string.adb [Ada] pragmarc-matching-character_regular_expression.adb [Ada] pragmarc-luhn_generation.adb [Ada] pragmarc-line_fields.adb [Ada] pragmarc-least_squares_fitting.adb [Ada] pragmarc-job_pools.adb [Ada] pragmarc-images.adb [Ada] pragmarc-images-image.ads [Ada] pragmarc-hash_fast_variable_length.adb [Ada] pragmarc-hash.adb [Ada] pragmarc-genetic_algorithm.adb [Ada] pragmarc-encryption.ads [Ada] pragmarc-encryption-threefish.adb [Ada] pragmarc-encryption-threefish-block_512.adb [Ada] pragmarc-encryption-threefish-block_256.adb [Ada] pragmarc-encryption-threefish-block_1024.adb [Ada] pragmarc-encryption-simple_xor.adb [Ada] pragmarc-encryption-bifid.adb [Ada] pragmarc-date_handler.adb [Ada] pragmarc-data_structures.ads [Ada] pragmarc-data_structures-stacks.ads [Ada] pragmarc-data_structures-stacks-unbounded.ads [Ada] pragmarc-data_structures-stacks-unbounded-unprotected.adb [Ada] pragmarc-data_structures-stacks-unbounded-protection.adb [Ada] pragmarc-data_structures-skip_lists.ads [Ada] pragmarc-data_structures-skip_lists-unbounded.adb [Ada] pragmarc-data_structures-sets.ads [Ada] pragmarc-data_structures-sets-discrete.adb [Ada] pragmarc-data_structures-queues.ads [Ada] pragmarc-data_structures-queues-unbounded.ads [Ada] pragmarc-data_structures-queues-unbounded-unprotected.adb [Ada] pragmarc-data_structures-queues-unbounded-protection.ads [Ada] pragmarc-data_structures-queues-unbounded-protection-non_blocking.adb [Ada] pragmarc-data_structures-queues-unbounded-protection-blocking.ads [Ada] pragmarc-data_structures-queues-bounded.ads [Ada] pragmarc-data_structures-queues-bounded-unprotected.adb [Ada] pragmarc-data_structures-queues-bounded-protection.ads [Ada] pragmarc-data_structures-queues-bounded-protection-non_blocking.adb [Ada] pragmarc-data_structures-queues-bounded-protection-blocking.ads [Ada] pragmarc-data_structures-lists.ads [Ada] pragmarc-data_structures-lists-unbounded.ads [Ada] pragmarc-data_structures-lists-unbounded-protection.adb [Ada] pragmarc-data_structures-lists-bounded.ads [Ada] pragmarc-data_structures-lists-bounded-protection.adb [Ada] pragmarc-data_structures-bags.ads [Ada] pragmarc-data_structures-bags-unbounded.ads [Ada] pragmarc-data_structures-bags-unbounded-unprotected.adb [Ada] pragmarc-data_structures-bags-unbounded-protection.adb [Ada] pragmarc-conversions.ads [Ada] pragmarc-conversions-vectors.adb [Ada] pragmarc-conversions-unbounded_strings.ads [Ada] pragmarc-concurrent_pipeline.adb [Ada] pragmarc-comparisons.ads [Ada] pragmarc-cards.ads [Ada] pragmarc-cards-us.adb [Ada] pragmarc-cards-decks.ads [Ada] pragmarc-cards-decks-us.adb [Ada] pragmarc-cards-decks-general.adb [Ada] pragmarc-b_strings.adb [Ada] pragmarc-binary_semaphore_handler.adb [Ada] pragmarc-binary_searcher.adb [Ada] pragmarc-ansi_tty_control.adb [Ada] compile_all.adb [Ada] crc_32_config.ads [Ada] crc_32.adb [Ada] image_io_config.ads [Ada] image_io.ads [Ada] image_io-qoi_holders.adb [Ada] image_io-qoi.adb image_io-qoi.ads:64:06: "Relaxed_Initialization" is not a valid aspect identifier image_io-qoi.ads:64:06: "Relaxed_Initialization" is not a valid aspect identifier compilation of image_io-qoi.adb failed compilation of image_io-qoi_holders.adb failed gprbuild: *** compilation phase failed stderr: Command ["gprbuild", "-s", "-j0", "-p", "-P", "D:\a\alire-crates-ci\alire-crates-ci\test\a7073f4f-e1a7-461c-881b-5892b856e682\image_io_20240725.0.0_e3fcdc57\image_io.gpr", "-cargs:Ada", "-gnatwn"] exited with code 4 ERROR: Command ["gprbuild", "-s", "-j0", "-p", "-P", "D:\a\alire-crates-ci\alire-crates-ci\test\a7073f4f-e1a7-461c-881b-5892b856e682\image_io_20240725.0.0_e3fcdc57\image_io.gpr", "-cargs:Ada", "-gnatwn"] exited with code 4 stderr: ALIRE.CHECKED_ERROR stderr: Command ["gprbuild", "-s", "-j0", "-p", "-P", "D:\a\alire-crates-ci\alire-crates-ci\test\a7073f4f-e1a7-461c-881b-5892b856e682\image_io_20240725.0.0_e3fcdc57\image_io.gpr", "-cargs:Ada", "-gnatwn"] exited with code 4 stderr: raised ALIRE.CHECKED_ERROR : alire-stored-error:1 [D:\a\alire-crates-ci\alire-crates-ci\alire_install\bin\alr.exe] 0x7ff7bfafda2a Semantic_Versioning.Basic.Restrictions.First_Index at alire.adb:284 0x7ff7bf6f595b Semantic_Versioning.Basic.Restrictions.First_Index at alire-os_lib-subprocess.adb:111 0x7ff7bf9acba1 Semantic_Versioning.Basic.Restrictions.First_Index at alire-spawn.adb:22 0x7ff7bf9add5d Semantic_Versioning.Basic.Restrictions.First_Index at alire-spawn.adb:68 0x7ff7bf8d2d64 Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:189 0x7ff7bf8d11da Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:255 0x7ff7bf8f912d Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2143 0x7ff7bf9682f9 Semantic_Versioning.Basic.Restrictions.First_Index at alire-solutions.adb:1472 0x7ff7bf967424 Semantic_Versioning.Basic.Restrictions.First_Index at alire-solutions.adb:1555 0x7ff7bf8f922c Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2147 0x7ff7bf8f92fa Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2127 0x7ff7bf8d17a7 Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:286 0x7ff7bf8d1912 Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:114 0x7ff7bf043baa Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:145 0x7ff7bf04341e Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:113 0x7ff7bf0435ba Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:54 0x7ff7bf0f5dea Semantic_Versioning.Basic.Restrictions.First_Index at clic-subcommand-instance.adb:749 0x7ff7bf102b0e Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands.adb:632 0x7ff7befd16a0 Alr.Main at alr-main.adb:13 0x7ff7befd5270 Main at b__alr-main.adb:2454 0x7ff7befd133e __tmainCRTStartup at ??? 0x7ff7befd1144 mainCRTStartup at ??? [C:\Windows\System32\KERNEL32.DLL] 0x7ffa4152e8d5 [C:\Windows\SYSTEM32\ntdll.dll] 0x7ffa42d48d9a stderr: ALIRE.ROOTS.BUILD._WRAPPED_STATEMENTS.BUILD_FAILED stderr: alire-roots.adb:202 stderr: raised ALIRE.ROOTS.BUILD._WRAPPED_STATEMENTS.BUILD_FAILED : alire-roots.adb:202 [D:\a\alire-crates-ci\alire-crates-ci\alire_install\bin\alr.exe] 0x7ff7bf8d313c Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:202 0x7ff7bf8d11da Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:255 0x7ff7bf8f912d Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2143 0x7ff7bf9682f9 Semantic_Versioning.Basic.Restrictions.First_Index at alire-solutions.adb:1472 0x7ff7bf967424 Semantic_Versioning.Basic.Restrictions.First_Index at alire-solutions.adb:1555 0x7ff7bf8f922c Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2147 0x7ff7bf8f92fa Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:2127 0x7ff7bf8d17a7 Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:286 0x7ff7bf8d1912 Semantic_Versioning.Basic.Restrictions.First_Index at alire-roots.adb:114 0x7ff7bf043baa Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:145 0x7ff7bf04341e Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:113 0x7ff7bf0435ba Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands-build.adb:54 0x7ff7bf0f5dea Semantic_Versioning.Basic.Restrictions.First_Index at clic-subcommand-instance.adb:749 0x7ff7bf102b0e Semantic_Versioning.Basic.Restrictions.First_Index at alr-commands.adb:632 0x7ff7befd16a0 Alr.Main at alr-main.adb:13 0x7ff7befd5270 Main at b__alr-main.adb:2454 0x7ff7befd133e __tmainCRTStartup at ??? 0x7ff7befd1144 mainCRTStartup at ??? [C:\Windows\System32\KERNEL32.DLL] 0x7ffa4152e8d5 [C:\Windows\SYSTEM32\ntdll.dll] 0x7ffa42d48d9a ERROR: Compilation failed.