Skip to content

Releases: OpenPrinting/pappl-retrofit

pappl-retrofit 1.0b2

07 Feb 18:01
Compare
Choose a tag to compare

This is the second beta release of the upcoming pappl-retrofit 1.0.0, to fix some issues in the source code documentation and to allow installation of the Legacy Printer Application as a permanently running system daemon.

  • Support for Legacy Printer Application as system daemon
    We have added a systemd *.service file and an install mode for installing the Legacy Printer Application as system daemon. The mode is triggered by the --enable-legacy-printer-app-as-daemon option for ./configure. Then the *.service file gets installed and the executable legacy-printer-app gets installed into /usr/(local/)sbin/.
  • README.md: Updated TODOs and fixed minor glitches
    Especially the PAPPL development got already far enough for localization and ink level reporting support, so that we do not need to tell any more that we are waiting for further the devlopment of PAPPL.
  • CONTRIBUTING.md: Updated text to reflect pappl-retrofit
  • COPYING, NOTICE: Fixed copyright year 2023 and simplified the file based on the fact that one can assign the package's license to all autotools-generated files.
  • Adapted DEVELOPING.md to the pappl-retrofit API, it was still reflecting the CUPS API (file was copied over from CUPS.
  • Removed _prDefaultPaperSize() from pappl-retrofit-private.h. The function got removed when PAPPL had introduced papplLocGetDefaultMediaSizeName() which replaces this functionality.

pappl-retrofit 1.0b1

09 Dec 20:23
Compare
Choose a tag to compare

This is the first beta release of the upcoming pappl-retrofit 1.0.0.

This is a library to convert classic CUPS drivers, consisting of PPD files, CUPS filters, and sometimes also CUPS backends, into Printer Applications, the new format of printer drivers, mainly for CUPS 3.x which goes all-IPP and does not support the PPD/filter concept for printer drivers any more. Printer Applications are emulations of driverless IPP printers which on their other end pass on the jobs to the actual printer.

pappl-retrofit uses PAPPL, library for Printer Applications, as its base, and so it does not need to care of the general functionality of Printer Applications. So it only contains the code to adapt classic CUPS drivers and PPD files into the Printer Application framework.

To support as many classic drivers as possible pappl-retrofit supports all kinds of PPD files, with and without specification of a CUPS filter, installable accessory settings, CUPS extension for custom option values, *.drv PPD compiler files, PPD-file-generating executables, CUPS filters, CUPS backends, side and back channels for filter/backend communication, pre-filtering from the driverless-IPP-standard input formats to the input formats of the driver filters.

pappl-retrofit also comes with the Legacy Printer Application, which when it is classically (not as Snap or other container) installed sees all classically installed CUPS drivers on the system and maps them into its IPP printer emulation, so that CUPS 3.x can make use of all these drivers. This way the user does not loose their old printer drivers on the transition to CUPS 3.x, which is especially important for (often proprietary) drivers from printer manufacturers.

As this library was developed along with the 4 retro-fitting Printer Applications for PostScript, Ghostscript, HPLIP, and Gutenprint as the base for them, it has grown with these applications and contains all functionality they need. It has also grown with PAPPL, getting support for PAPPL's newest features.

So we are not releasing now because we completed a pre-planned feature list but rather to have releases of this package and the Printer Applications for their easier adoption into Linux distributions. With this we will also version the Printer Application Snaps in the Snap Store, so that when distributions adopt them as their default printer drivers, they can also better manage their customer support.

Feature-wise we are even not 100% complete. We will still add ink level read-out from the printer (SNMP-based network printers, same as supported by CUPS) and internationalization, but this will not cause any compatibility-breaking API changes.