SplPdAbortDoc: Difference between revisions
Appearance
	
	
| mNo edit summary | No edit summary | ||
| Line 7: | Line 7: | ||
| == Parameters == | == Parameters == | ||
| ; hDevice (HFILE) - input:Handle from SplPdOpen. | ; ''hDevice'' ([[HFILE]]) - input:Handle from SplPdOpen. | ||
| ;pchData (PVOID) - input:Pointer to data buffer to write after flushing all current write data. | ;''pchData'' ([[PVOID]]) - input:Pointer to data buffer to write after flushing all current write data. | ||
| ;cbData (ULONG) - input:Length of data, in bytes. | ;''cbData'' ([[ULONG]]) - input:Length of data, in bytes. | ||
| :May be 0 (zero) for no data to write. | :May be 0 (zero) for no data to write. | ||
| ;ulFlags (ULONG) - input:Abort processing flags. | ;''ulFlags'' (ULONG) - input:Abort processing flags. | ||
| :Value is as follows: | :Value is as follows: | ||
| ::FLG_COMPLETE_DATA - 0x00000001 : If set, then all prior data for this job must be sent to the printer. | ::FLG_COMPLETE_DATA - 0x00000001 : If set, then all prior data for this job must be sent to the printer. | ||
| == Returns == | == Returns == | ||
| ; rc (ULONG) - returns : Return codes. | ; ''rc'' ([[ULONG]]) - returns : Return codes. | ||
| *0 Success | *0 Success | ||
Latest revision as of 03:25, 3 September 2025
SplPdAbortDoc is an API exported by port drivers. It is called by PrtAbort and PrtAbortDoc for document-abort processing. If FLG_COMPLETE_DATA is set, all prior data for this job is sent to the printer. If FLG_COMPLETE_DATA is not set, all current write requests for this job are flushed and then the buffer of data is sent to reset the printer.
FLG_COMPLETE_DATA is always set if the printer driver calls PrtAbort, because some older printer drivers send the reset sequence to the printer using PrtWrite, then call PrtAbort to abort the job. In this case, the printer driver relies on only PrtWrite returning after the data was sent to the printer.
Syntax
SplPdAbortDoc(hDevice, pchData, cbData, ulFlags)
Parameters
- hDevice (HFILE) - input
- Handle from SplPdOpen.
- pchData (PVOID) - input
- Pointer to data buffer to write after flushing all current write data.
- cbData (ULONG) - input
- Length of data, in bytes.
- May be 0 (zero) for no data to write.
- ulFlags (ULONG) - input
- Abort processing flags.
- Value is as follows:
- FLG_COMPLETE_DATA - 0x00000001 : If set, then all prior data for this job must be sent to the printer.
 
Returns
- rc (ULONG) - returns
- Return codes.
- 0 Success
- 6(ERROR_INVALID_HANDLE) :Invalid handle given.
- 29(ERROR_WRITE_FAULT) :Failure attempting to write reset sequence to the device.
Sample
#define INCL_SPL #define INCL_SPLBIDI #include <os2.h> HFILE hDevice; /* Handle from SplPdOpen. */ PVOID pchData; /* Pointer to data buffer to write after flushing all current write data. */ ULONG cbData; /* Length of data, in bytes. */ ULONG ulFlags; /* Abort processing flags. */ ULONG rc; /* Return codes. */ rc = SplPdAbortDoc(hDevice, pchData, cbData, ulFlags);
Remarks
SplPdClose must still be issued to close the device connection.