GreEscape DEVESC_DEFAULTJOBPROPERTIES is used to default individual DJP_ITEMs rather than defaulting the entire job property structure. This structure is known only to the printer presentation driver, and this escape is the only way for an application to reset values inside the structure.
Since this function is new, applications will call GreEscape DEVESC_QUERYESCSUPPORT to determine if you support this DevEscape.
Note that the DevEscape path has a handle to a device context (HDC) that should already have printer property information associated with the HDC. Job property information may change or may be dependent upon the printer property information in the HDC. In that case, if an application passes job properties for a different device or for a different spooler printer name, then misleading information will be returned.
Remember to test the input job properties to make sure that they are valid. This includes passing tests such as whether they contain your driver's signature string, whether the device name is yours, and whether values are within the proper ranges (only landscape or portrait). If these tests fail, then fail the call.
LONG ENGENTRY Escape (HDC hdc, LONG lEscape, LONG cInCount, PBYTE pInData, PLONG pcOutCount, PBYTE pOutData, PDDC pddc, ULONG ulFunction) { switch (lEscape) { case DEVESC_DEFAULTJOBPROPERTIES: { INT cbQueries = cInCount; PBYTE pbQueries = pInData; PDJP_ITEM pISet = (PDJP_ITEM)pbQueries; BOOL fError = FALSE; ULONG ulMaxSize; pGoodDrivData = ReturnDriverData (pddc->pdb, pdi, pddc->pdb->hmcbHeap, pDrivData, pddc->pdb->pszPrinterName, TRUE, pDevice, pDriver); assertF (pGoodDrivData); /* Is the size of the input driver data is not the same as ** the size of our good data? */ if (pDrivData->cb != pGoodDrivData->cb) lrc = DEV_PROP_BUF_TOO_SMALL; /* Or, if the two don't compare, then fail the call. */ if (0 != memcmp (pDrivData, pGoodDrivData, pGoodDrivData->cb)) lrc = DEV_INV_INP_JOBPROPERTIES; // Update the job properties with the input set list do { DBPRINTF (("Set default '%s'/%d. Query type '%s'/%d. Simple value = %d\n", pszProperty (pISet->ulProperty), pISet->ulProperty, pszType (pISet->lType), pISet->lType, pISet->ulValue)); switch (pISet->ulProperty) { case DJP_SJ_ORIENTATION: { pJobProp->ulOrientation = pDevice->DeviceDefaults.ulOrientation; break; } case DJP_CJ_RESOLUTION: { pJobProp->ulDefResID = pDevice->DeviceDefaults.ulDefResID; break; } case DJP_SJ_BITSPERPEL: case DJP_SJ_COLOR: { pJobProp->ulDefPrintModeID = pDevice->DeviceDefaults.ulDefPrintModeID; break; } case DJP_SJ_PAPERSIZE: case DJP_CJ_FORM: { pJobProp->ulDefConnID = pDevice->DeviceDefaults.ulDefConnID; break; } case DJP_SJ_COPIES: { pJobProp->ulCopies = pDevice->DeviceDefaults.ulCopies; break; } case DJP_SJ_PRINTQUALITY: case DJP_SJ_TRAYTYPE: case DJP_SJ_MEDIA: case DJP_SJ_MEDIA_COLOR: case DJP_CJ_MIXEDFORMS: case DJP_SJ_FONTDOWNLOADING: case DJP_SJ_DUPLEX: case DJP_SJ_COLLATE: case DJP_SJ_FEED: case DJP_SJ_SCALING: case DJP_SJ_FORMFEEDCONTROL: case DJP_SJ_N_UP: default: fError = TRUE; pISet->lType = DJP_ERROR_NOT_SUPPORTED; DBPRINTF (("Unknow set default '%s' = %d!\n", pszProperty (pISet->ulProperty), pISet->ulProperty)); break; } // Move to the set item pISet = DJP_NEXT_STRUCTP (pISet); } while (pISet->ulProperty != DJP_NONE); cbDrivData = cbParm2; pDrivData = (PDRIVDATA)pbParm2; /* Copy the updated job properties onto the user's job properties */ ulMaxSize = min (pGoodDrivData->cb, cbDrivData); memcpy (pDrivData, pGoodDrivData, ulMaxSize); pDrivData->cb = ulMaxSize; if (fError) { GplErrSetWarning (PMERR_DATATYPE_ENTRY_INVALID); ulrc = DEV_ERROR; } else { ulrc = DEV_OK; } break; } } return lrc; }