]> git.ipfire.org Git - thirdparty/cups.git/blobdiff - cups/ipp.h
Merge pull request #5621 from zdohnal/cgigetarray-sigsegv
[thirdparty/cups.git] / cups / ipp.h
index feea0899f50e2e5a3eafd58e7e0eb2f1b58b3d9e..b7412a40c47672b4fb2b9209fd93e3c51d2b7f4e 100644 (file)
@@ -1,16 +1,11 @@
 /*
  * Internet Printing Protocol definitions for CUPS.
  *
- * Copyright 2007-2017 by Apple Inc.
- * Copyright 1997-2006 by Easy Software Products.
+ * Copyright © 2007-2018 by Apple Inc.
+ * Copyright © 1997-2006 by Easy Software Products.
  *
- * These coded instructions, statements, and computer programs are the
- * property of Apple Inc. and are protected by Federal copyright
- * law.  Distribution and use rights are outlined in the file "LICENSE.txt"
- * which should have been included with this file.  If this file is
- * missing or damaged, see the license at "http://www.cups.org/".
- *
- * This file is subject to the Apple OS-Developed Software exception.
+ * Licensed under Apache License v2.0.  See the file "LICENSE" for more
+ * information.
  */
 
 #ifndef _CUPS_IPP_H_
@@ -79,11 +74,11 @@ extern "C" {
 
 typedef enum ipp_dstate_e              /**** Document states @exclude all@ ****/
 {
-  IPP_DOCUMENT_PENDING = 3,            /* Document is pending */
-  IPP_DOCUMENT_PROCESSING = 5,         /* Document is processing */
-  IPP_DOCUMENT_CANCELED = 7,           /* Document is canceled */
-  IPP_DOCUMENT_ABORTED,                        /* Document is aborted */
-  IPP_DOCUMENT_COMPLETED               /* Document is completed */
+  IPP_DSTATE_PENDING = 3,              /* Document is pending */
+  IPP_DSTATE_PROCESSING = 5,           /* Document is processing */
+  IPP_DSTATE_CANCELED = 7,             /* Document is canceled */
+  IPP_DSTATE_ABORTED,                  /* Document is aborted */
+  IPP_DSTATE_COMPLETED                 /* Document is completed */
 
 #  ifndef _CUPS_NO_DEPRECATED
 #    define IPP_DOCUMENT_PENDING       IPP_DSTATE_PENDING
@@ -150,11 +145,11 @@ typedef enum ipp_finishings_e             /**** Finishings values ****/
   IPP_FINISHINGS_PUNCH_QUAD_TOP,       /* Punch 4 holes top edge */
   IPP_FINISHINGS_PUNCH_QUAD_RIGHT,     /* Punch 4 holes right side */
   IPP_FINISHINGS_PUNCH_QUAD_BOTTOM,    /* Punch 4 holes bottom edge */
-  IPP_FINISHINGS_PUNCH_MULTIPLE_LEFT,  /* Pucnh multiple holes left side */
-  IPP_FINISHINGS_PUNCH_MULTIPLE_TOP,   /* Pucnh multiple holes top edge */
-  IPP_FINISHINGS_PUNCH_MULTIPLE_RIGHT, /* Pucnh multiple holes right side */
-  IPP_FINISHINGS_PUNCH_MULTIPLE_BOTTOM,        /* Pucnh multiple holes bottom edge */
-  IPP_FINISHINGS_FOLD_ACCORDIAN = 90,  /* Accordian-fold the paper vertically into four sections */
+  IPP_FINISHINGS_PUNCH_MULTIPLE_LEFT,  /* Punch multiple holes left side */
+  IPP_FINISHINGS_PUNCH_MULTIPLE_TOP,   /* Punch multiple holes top edge */
+  IPP_FINISHINGS_PUNCH_MULTIPLE_RIGHT, /* Punch multiple holes right side */
+  IPP_FINISHINGS_PUNCH_MULTIPLE_BOTTOM,        /* Punch multiple holes bottom edge */
+  IPP_FINISHINGS_FOLD_ACCORDION = 90,  /* Accordion-fold the paper vertically into four sections */
   IPP_FINISHINGS_FOLD_DOUBLE_GATE,     /* Fold the top and bottom quarters of the paper towards the midline, then fold in half vertically */
   IPP_FINISHINGS_FOLD_GATE,            /* Fold the top and bottom quarters of the paper towards the midline */
   IPP_FINISHINGS_FOLD_HALF,            /* Fold the paper in half vertically */
@@ -189,8 +184,8 @@ typedef enum ipp_finishings_e               /**** Finishings values ****/
   IPP_FINISHINGS_CUPS_PUNCH_QUAD_RIGHT,        /* Punch 4 holes right side @exclude all@ */
   IPP_FINISHINGS_CUPS_PUNCH_QUAD_BOTTOM,/* Punch 4 holes bottom edge @exclude all@ */
 
-  IPP_FINISHINGS_CUPS_FOLD_ACCORDIAN = 0x4000005A,
-                                       /* Accordian-fold the paper vertically into four sections @exclude all@ */
+  IPP_FINISHINGS_CUPS_FOLD_ACCORDION = 0x4000005A,
+                                       /* Accordion-fold the paper vertically into four sections @exclude all@ */
   IPP_FINISHINGS_CUPS_FOLD_DOUBLE_GATE,        /* Fold the top and bottom quarters of the paper towards the midline, then fold in half vertically @exclude all@ */
   IPP_FINISHINGS_CUPS_FOLD_GATE,       /* Fold the top and bottom quarters of the paper towards the midline @exclude all@ */
   IPP_FINISHINGS_CUPS_FOLD_HALF,       /* Fold the paper in half vertically @exclude all@ */
@@ -203,8 +198,10 @@ typedef enum ipp_finishings_e              /**** Finishings values ****/
   IPP_FINISHINGS_CUPS_FOLD_Z           /* Fold the paper vertically into three sections, forming a Z @exclude all@ */
 } ipp_finishings_t;
 #  ifndef _CUPS_NO_DEPRECATED
+#    define IPP_FINISHINGS_CUPS_FOLD_ACCORDIAN IPP_FINISHINGS_CUPS_FOLD_ACCORDION
+#    define IPP_FINISHINGS_FOLD_ACCORDIAN IPP_FINISHINGS_FOLD_ACCORDION
 #    define IPP_FINISHINGS_JOB_OFFSET  IPP_FINISHINGS_JOG_OFFSET
-                                       /* Long-time misspelling... */
+                                       /* Long-time misspellings... */
 typedef enum ipp_finishings_e ipp_finish_t;
 #  endif /* !_CUPS_NO_DEPRECATED */
 
@@ -276,7 +273,7 @@ typedef enum ipp_op_e                       /**** IPP operations ****/
   IPP_OP_GET_NOTIFICATIONS,            /* Get-Notifications: Get notification events @since CUPS 1.2/macOS 10.5@ */
   IPP_OP_SEND_NOTIFICATIONS,           /* Send-Notifications: Send notification events @private@ */
   IPP_OP_GET_RESOURCE_ATTRIBUTES,      /* Get-Resource-Attributes: Get resource information @private@ */
-  IPP_OP_GET_RESOURCE_DATA,            /* Get-Resource-Data: Get resource data @private@ */
+  IPP_OP_GET_RESOURCE_DATA,            /* Get-Resource-Data: Get resource data @private@ @deprecated@ */
   IPP_OP_GET_RESOURCES,                        /* Get-Resources: Get list of resources @private@ */
   IPP_OP_GET_PRINT_SUPPORT_FILES,      /* Get-Printer-Support-Files: Get printer support files @private@ */
   IPP_OP_ENABLE_PRINTER,               /* Enable-Printer: Accept new jobs for a printer */
@@ -321,6 +318,33 @@ typedef enum ipp_op_e                      /**** IPP operations ****/
   IPP_OP_UPDATE_OUTPUT_DEVICE_ATTRIBUTES,
                                        /* Update-Output-Device-Attributes: Update output device values @exclude all@ */
   IPP_OP_GET_NEXT_DOCUMENT_DATA,       /* Get-Next-Document-Data: Scan more document data @exclude all@ */
+  IPP_OP_ALLOCATE_PRINTER_RESOURCES,    /* Allocate-Printer-Resources: Use resources for a printer. */
+  IPP_OP_CREATE_PRINTER,                /* Create-Printer: Create a new service. */
+  IPP_OP_DEALLOCATE_PRINTER_RESOURCES,  /* Deallocate-Printer-Resources: Stop using resources for a printer. */
+  IPP_OP_DELETE_PRINTER,                /* Delete-Printer: Delete an existing service. */
+  IPP_OP_GET_PRINTERS,                  /* Get-Printers: Get a list of services. */
+  IPP_OP_SHUTDOWN_ONE_PRINTER,          /* Shutdown-One-Printer: Shutdown a service. */
+  IPP_OP_STARTUP_ONE_PRINTER,           /* Startup-One-Printer: Start a service. */
+  IPP_OP_CANCEL_RESOURCE,               /* Cancel-Resource: Uninstall a resource. */
+  IPP_OP_CREATE_RESOURCE,               /* Create-Resource: Create a new (empty) resource. */
+  IPP_OP_INSTALL_RESOURCE,              /* Install-Resource: Install a resource. */
+  IPP_OP_SEND_RESOURCE_DATA,            /* Send-Resource-Data: Upload the data for a resource. */
+  IPP_OP_SET_RESOURCE_ATTRIBUTES,       /* Set-Resource-Attributes: Set resource object  attributes. */
+  IPP_OP_CREATE_RESOURCE_SUBSCRIPTIONS, /* Create-Resource-Subscriptions: Create event subscriptions for a resource. */
+  IPP_OP_CREATE_SYSTEM_SUBSCRIPTIONS,   /* Create-System-Subscriptions: Create event subscriptions for a system. */
+  IPP_OP_DISABLE_ALL_PRINTERS,          /* Disable-All-Printers: Stop accepting new jobs on all services. */
+  IPP_OP_ENABLE_ALL_PRINTERS,           /* Enable-All-Printers: Start accepting new jobs on all services. */
+  IPP_OP_GET_SYSTEM_ATTRIBUTES,         /* Get-System-Attributes: Get system object attributes. */
+  IPP_OP_GET_SYSTEM_SUPPORTED_VALUES,   /* Get-System-Supported-Values: Get supported values for system object attributes. */
+  IPP_OP_PAUSE_ALL_PRINTERS,            /* Pause-All-Printers: Stop all services immediately. */
+  IPP_OP_PAUSE_ALL_PRINTERS_AFTER_CURRENT_JOB,
+                                        /* Pause-All-Printers-After-Current-Job: Stop all services after processing the current jobs. */
+  IPP_OP_REGISTER_OUTPUT_DEVICE,        /* Register-Output-Device: Register a remote service. */
+  IPP_OP_RESTART_SYSTEM,                /* Restart-System: Restart all services. */
+  IPP_OP_RESUME_ALL_PRINTERS,           /* Resume-All-Printers: Start job processing on all services. */
+  IPP_OP_SET_SYSTEM_ATTRIBUTES,         /* Set-System-Attributes: Set system object attributes. */
+  IPP_OP_SHUTDOWN_ALL_PRINTERS,         /* Shutdown-All-Printers: Shutdown all services. */
+  IPP_OP_STARTUP_ALL_PRINTERS,          /* Startup-All-Printers: Startup all services. */
 
   IPP_OP_PRIVATE = 0x4000,             /* Reserved @private@ */
   IPP_OP_CUPS_GET_DEFAULT,             /* CUPS-Get-Default: Get the default printer */
@@ -442,7 +466,7 @@ typedef enum ipp_orient_e           /**** Orientation values ****/
 #  endif /* !_CUPS_NO_DEPRECATED */
 } ipp_orient_t;
 
-typedef enum ipp_pstate_e              /**** Printer states ****/
+typedef enum ipp_pstate_e              /**** Printer state values ****/
 {
   IPP_PSTATE_IDLE = 3,                 /* Printer is idle */
   IPP_PSTATE_PROCESSING,               /* Printer is working */
@@ -455,7 +479,7 @@ typedef enum ipp_pstate_e           /**** Printer states ****/
 #  endif /* _CUPS_NO_DEPRECATED */
 } ipp_pstate_t;
 
-typedef enum ipp_quality_e             /**** Qualities ****/
+typedef enum ipp_quality_e             /**** Print quality values ****/
 {
   IPP_QUALITY_DRAFT = 3,               /* Draft quality */
   IPP_QUALITY_NORMAL,                  /* Normal quality */
@@ -468,7 +492,23 @@ typedef enum ipp_res_e                     /**** Resolution units ****/
   IPP_RES_PER_CM                       /* Pixels per centimeter */
 } ipp_res_t;
 
-typedef enum ipp_state_e               /**** IPP states ****/
+typedef enum ipp_rstate_e              /**** resource-state values ****/
+{
+  IPP_RSTATE_PENDING = 3,              /* Resource is created but has no data yet. */
+  IPP_RSTATE_AVAILABLE,                        /* Resource is available for installation. */
+  IPP_RSTATE_INSTALLED,                        /* Resource is installed.  */
+  IPP_RSTATE_CANCELED,                 /* Resource has been canceled and is pending deletion. */
+  IPP_RSTATE_ABORTED                   /* Resource has been aborted and is pending deletion. */
+} ipp_rstate_t;
+
+typedef enum ipp_sstate_e              /**** system-state values ****/
+{
+  IPP_SSTATE_IDLE = 3,                 /* At least one printer is idle and none are processing a job. */
+  IPP_SSTATE_PROCESSING,               /* At least one printer is processing a job. */
+  IPP_SSTATE_STOPPED                   /* All printers are stopped. */
+} ipp_sstate_t;
+
+typedef enum ipp_state_e               /**** ipp_t state values ****/
 {
   IPP_STATE_ERROR = -1,                        /* An error occurred */
   IPP_STATE_IDLE,                      /* Nothing is happening/request completed */
@@ -485,7 +525,7 @@ typedef enum ipp_state_e            /**** IPP states ****/
 #  endif /* !_CUPS_NO_DEPRECATED */
 } ipp_state_t;
 
-typedef enum ipp_status_e              /**** IPP status codes ****/
+typedef enum ipp_status_e              /**** IPP status code values ****/
 {
   IPP_STATUS_CUPS_INVALID = -1,                /* Invalid status name for @link ippErrorValue@ */
   IPP_STATUS_OK = 0x0000,              /* successful-ok */
@@ -636,7 +676,7 @@ typedef enum ipp_status_e           /**** IPP status codes ****/
 #  endif /* _CUPS_NO_DEPRECATED */
 } ipp_status_t;
 
-typedef enum ipp_tag_e                 /**** Format tags for attributes ****/
+typedef enum ipp_tag_e                 /**** Value and group tag values for attributes ****/
 {
   IPP_TAG_CUPS_INVALID = -1,           /* Invalid tag name for @link ippTagValue@ */
   IPP_TAG_ZERO = 0x00,                 /* Zero tag - used for separators */
@@ -647,8 +687,9 @@ typedef enum ipp_tag_e                      /**** Format tags for attributes ****/
   IPP_TAG_UNSUPPORTED_GROUP,           /* Unsupported attributes group */
   IPP_TAG_SUBSCRIPTION,                        /* Subscription group */
   IPP_TAG_EVENT_NOTIFICATION,          /* Event group */
-  IPP_TAG_RESOURCE,                    /* Resource group @private@ */
-  IPP_TAG_DOCUMENT,                    /* Document group @exclude all@ */
+  IPP_TAG_RESOURCE,                    /* Resource group */
+  IPP_TAG_DOCUMENT,                    /* Document group */
+  IPP_TAG_SYSTEM,                       /* System group */
   IPP_TAG_UNSUPPORTED_VALUE = 0x10,    /* Unsupported value */
   IPP_TAG_DEFAULT,                     /* Default value */
   IPP_TAG_UNKNOWN,                     /* Unknown value */
@@ -695,145 +736,11 @@ typedef struct _ipp_attribute_s ipp_attribute_t;
 
 /**** New in CUPS 1.2/macOS 10.5 ****/
 typedef ssize_t        (*ipp_iocb_t)(void *context, ipp_uchar_t *buffer, size_t bytes);
-                                       /**** IPP IO Callback Function @since CUPS 1.2/macOS 10.5@ ****/
+                                       /**** ippReadIO/ippWriteIO callback function @since CUPS 1.2/macOS 10.5@ ****/
 
 /**** New in CUPS 1.6/macOS 10.8 ****/
 typedef int (*ipp_copycb_t)(void *context, ipp_t *dst, ipp_attribute_t *attr);
-
-
-/*
- * The following structures are PRIVATE starting with CUPS 1.6/macOS 10.8.
- * Please use the new accessor functions available in CUPS 1.6 and later, as
- * these definitions will be moved to a private header file in a future release.
- *
- * Define _IPP_PRIVATE_STRUCTURES to 1 to cause the private IPP structures to be
- * exposed in CUPS 1.6.  This happens automatically on macOS when compiling for
- * a deployment target of 10.7 or earlier.
- *
- * Define _IPP_PRIVATE_STRUCTURES to 0 to prevent the private IPP structures
- * from being exposed.  This is useful when migrating existing code to the new
- * accessors.
- */
-
-#  ifdef _IPP_PRIVATE_STRUCTURES
-     /* Somebody has overridden the value */
-#  elif defined(_CUPS_SOURCE) || defined(_CUPS_IPP_PRIVATE_H_)
-     /* Building CUPS */
-#    define _IPP_PRIVATE_STRUCTURES 1
-#  elif defined(__APPLE__)
-#    if defined(MAC_OS_X_VERSION_10_8) && MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_8
-       /* Building for 10.7 and earlier */
-#      define _IPP_PRIVATE_STRUCTURES 1
-#    elif !defined(MAC_OS_X_VERSION_10_8)
-       /* Building for 10.7 and earlier */
-#      define _IPP_PRIVATE_STRUCTURES 1
-#    endif /* MAC_OS_X_VERSION_10_8 && MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_8 */
-#  else
-#    define _IPP_PRIVATE_STRUCTURES 0
-#  endif /* _CUPS_SOURCE || _CUPS_IPP_PRIVATE_H_ */
-
-#  if _IPP_PRIVATE_STRUCTURES
-typedef union _ipp_request_u           /**** Request Header ****/
-{
-  struct                               /* Any Header */
-  {
-    ipp_uchar_t        version[2];             /* Protocol version number */
-    int                op_status;              /* Operation ID or status code*/
-    int                request_id;             /* Request ID */
-  }            any;
-
-  struct                               /* Operation Header */
-  {
-    ipp_uchar_t        version[2];             /* Protocol version number */
-    ipp_op_t   operation_id;           /* Operation ID */
-    int                request_id;             /* Request ID */
-  }            op;
-
-  struct                               /* Status Header */
-  {
-    ipp_uchar_t        version[2];             /* Protocol version number */
-    ipp_status_t status_code;          /* Status code */
-    int                request_id;             /* Request ID */
-  }            status;
-
-  /**** New in CUPS 1.1.19 ****/
-  struct                               /* Event Header @since CUPS 1.1.19/macOS 10.3@ */
-  {
-    ipp_uchar_t        version[2];             /* Protocol version number */
-    ipp_status_t status_code;          /* Status code */
-    int                request_id;             /* Request ID */
-  }            event;
-} _ipp_request_t;
-
-/**** New in CUPS 1.1.19 ****/
-
-typedef union _ipp_value_u             /**** Attribute Value ****/
-{
-  int          integer;                /* Integer/enumerated value */
-
-  char         boolean;                /* Boolean value */
-
-  ipp_uchar_t  date[11];               /* Date/time value */
-
-  struct
-  {
-    int                xres,                   /* Horizontal resolution */
-               yres;                   /* Vertical resolution */
-    ipp_res_t  units;                  /* Resolution units */
-  }            resolution;             /* Resolution value */
-
-  struct
-  {
-    int                lower,                  /* Lower value */
-               upper;                  /* Upper value */
-  }            range;                  /* Range of integers value */
-
-  struct
-  {
-    char       *language;              /* Language code */
-    char       *text;                  /* String */
-  }            string;                 /* String with language value */
-
-  struct
-  {
-    int                length;                 /* Length of attribute */
-    void       *data;                  /* Data in attribute */
-  }            unknown;                /* Unknown attribute type */
-
-/**** New in CUPS 1.1.19 ****/
-  ipp_t                *collection;            /* Collection value @since CUPS 1.1.19/macOS 10.3@ */
-} _ipp_value_t;
-typedef _ipp_value_t ipp_value_t;      /**** Convenience typedef that will be removed @private@ ****/
-
-struct _ipp_attribute_s                        /**** Attribute ****/
-{
-  ipp_attribute_t *next;               /* Next attribute in list */
-  ipp_tag_t    group_tag,              /* Job/Printer/Operation group tag */
-               value_tag;              /* What type of value is it? */
-  char         *name;                  /* Name of attribute */
-  int          num_values;             /* Number of values */
-  _ipp_value_t values[1];              /* Values */
-};
-
-struct _ipp_s                          /**** IPP Request/Response/Notification ****/
-{
-  ipp_state_t          state;          /* State of request */
-  _ipp_request_t       request;        /* Request header */
-  ipp_attribute_t      *attrs;         /* Attributes */
-  ipp_attribute_t      *last;          /* Last attribute in list */
-  ipp_attribute_t      *current;       /* Current attribute (for read/write) */
-  ipp_tag_t            curtag;         /* Current attribute group tag */
-
-/**** New in CUPS 1.2 ****/
-  ipp_attribute_t      *prev;          /* Previous attribute (for read) @since CUPS 1.2/macOS 10.5@ */
-
-/**** New in CUPS 1.4.4 ****/
-  int                  use;            /* Use count @since CUPS 1.4.4/macOS 10.6.?@ */
-/**** New in CUPS 2.0 ****/
-  int                  atend,          /* At end of list? */
-                       curindex;       /* Current attribute index for hierarchical search */
-};
-#  endif /* _IPP_PRIVATE_STRUCTURES */
+                                        /**** ippCopyAttributes callback function @since CUPS 1.6/macOS 10.8 ****/
 
 
 /*
@@ -841,52 +748,52 @@ struct _ipp_s                             /**** IPP Request/Response/Notification ****/
  */
 
 extern ipp_attribute_t *ippAddBoolean(ipp_t *ipp, ipp_tag_t group,
-                                      const char *name, char value);
+                                      const char *name, char value) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddBooleans(ipp_t *ipp, ipp_tag_t group,
                                        const char *name, int num_values,
-                                       const char *values);
+                                       const char *values) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddDate(ipp_t *ipp, ipp_tag_t group,
-                                   const char *name, const ipp_uchar_t *value);
+                                   const char *name, const ipp_uchar_t *value) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddInteger(ipp_t *ipp, ipp_tag_t group,
                                       ipp_tag_t value_tag, const char *name,
-                                      int value);
+                                      int value) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddIntegers(ipp_t *ipp, ipp_tag_t group,
                                        ipp_tag_t value_tag, const char *name,
-                                       int num_values, const int *values);
+                                       int num_values, const int *values) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddRange(ipp_t *ipp, ipp_tag_t group,
-                                    const char *name, int lower, int upper);
+                                    const char *name, int lower, int upper) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddRanges(ipp_t *ipp, ipp_tag_t group,
                                      const char *name, int num_values,
-                                     const int *lower, const int *upper);
+                                     const int *lower, const int *upper) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddResolution(ipp_t *ipp, ipp_tag_t group,
                                          const char *name, ipp_res_t units,
-                                         int xres, int yres);
+                                         int xres, int yres) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddResolutions(ipp_t *ipp, ipp_tag_t group,
                                           const char *name, int num_values,
                                           ipp_res_t units, const int *xres,
-                                          const int *yres);
-extern ipp_attribute_t *ippAddSeparator(ipp_t *ipp);
+                                          const int *yres) _CUPS_PUBLIC;
+extern ipp_attribute_t *ippAddSeparator(ipp_t *ipp) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddString(ipp_t *ipp, ipp_tag_t group,
                                      ipp_tag_t value_tag, const char *name,
-                                     const char *language, const char *value);
+                                     const char *language, const char *value) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippAddStrings(ipp_t *ipp, ipp_tag_t group,
                                       ipp_tag_t value_tag, const char *name,
                                       int num_values, const char *language,
-                                      const char * const *values);
-extern time_t          ippDateToTime(const ipp_uchar_t *date);
-extern void            ippDelete(ipp_t *ipp);
-extern const char      *ippErrorString(ipp_status_t error);
+                                      const char * const *values) _CUPS_PUBLIC;
+extern time_t          ippDateToTime(const ipp_uchar_t *date) _CUPS_PUBLIC;
+extern void            ippDelete(ipp_t *ipp) _CUPS_PUBLIC;
+extern const char      *ippErrorString(ipp_status_t error) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippFindAttribute(ipp_t *ipp, const char *name,
-                                         ipp_tag_t value_tag);
+                                         ipp_tag_t value_tag) _CUPS_PUBLIC;
 extern ipp_attribute_t *ippFindNextAttribute(ipp_t *ipp, const char *name,
-                                             ipp_tag_t value_tag);
-extern size_t          ippLength(ipp_t *ipp);
-extern ipp_t           *ippNew(void);
-extern ipp_state_t     ippRead(http_t *http, ipp_t *ipp);
-extern const ipp_uchar_t *ippTimeToDate(time_t t);
-extern ipp_state_t     ippWrite(http_t *http, ipp_t *ipp);
-extern int             ippPort(void);
-extern void            ippSetPort(int p);
+                                             ipp_tag_t value_tag) _CUPS_PUBLIC;
+extern size_t          ippLength(ipp_t *ipp) _CUPS_PUBLIC;
+extern ipp_t           *ippNew(void) _CUPS_PUBLIC;
+extern ipp_state_t     ippRead(http_t *http, ipp_t *ipp) _CUPS_PUBLIC;
+extern const ipp_uchar_t *ippTimeToDate(time_t t) _CUPS_PUBLIC;
+extern ipp_state_t     ippWrite(http_t *http, ipp_t *ipp) _CUPS_PUBLIC;
+extern int             ippPort(void) _CUPS_PUBLIC;
+extern void            ippSetPort(int p) _CUPS_PUBLIC;
 
 /**** New in CUPS 1.1.19 ****/
 extern ipp_attribute_t *ippAddCollection(ipp_t *ipp, ipp_tag_t group,