Security Advisories (1)
CVE-2026-7111 (2026-04-29)

Text::CSV_XS versions before 1.62 for Perl have a use-after-free when registered callbacks extend the Perl argument stack, which may enable type confusion or memory corruption. The Parse, print, getline, and getline_all methods invoke registered callbacks (for example after_parse, before_print, or on_error) and cache the Perl argument stack pointer across the call. If a callback extends the argument stack enough to trigger a reallocation, the return value is written through the stale pointer into the freed buffer, and the caller reads the original $self argument as the return value instead. Calling code that expects parsed data from getline_all receives the Text::CSV_XS object in its place, leading to logic errors or crashes. Text::CSV_XS objects used without any registered callbacks are not affected.

Changes for version 1.53 - 2023-11-22

  • Two casts for -Wformat (issue 50)
  • Add --skip-empty to csv2xlsx
  • Add --font and --font-size to csv2xlsx
  • Fix skip_empty_rows ("skip") and trailing newlines (Corey Hickey, PR#52)
  • Fix comment in last line (RT#150501)

Documentation

Modules

comma-separated values manipulation routines