Jump to content

DosPeekNPipe: Difference between revisions

From EDM2
Ak120 (talk | contribs)
mNo edit summary
Line 1: Line 1:
=== Syntax ===
=== Syntax ===
  rc = DosPeekNPipe( ''hpipeHandle'',  
  rc = DosPeekNPipe( ''hpipeHandle'',  
                     ''pBuffer'',  
                     ''pBuffer'',  
Line 9: Line 8:


=== Parameters ===
=== Parameters ===
HPIPE ''hpipeHandle'' (input)
;HPIPE ''hpipeHandle'' (input):Handle of the named pipe to examine. It is returned by [[DosCreateNPipe]] (for the server) or [[DosOpen]] (for the client).
 
;PVOID ''pBuffer'' (output):This is a pointer to a output buffer.
Handle of the named pipe to examine. It is returned by [[OS2 API:CPI:DosCreateNPipe|DosCreateNPipe]] (for the server) or [[OS2 API:CPI:DosOpen|DosOpen]] (for the client).
;ULONG ''ulBufferLen'' (input):The number of bytes to read.
 
;PULONG ''pBytesRead'' (output):A pointer to a variable that will contain the number of bytes actually read.
 
;PAVAILDATA ''pBytesAvail'' (output):This is a pointer to a 4-byte buffer. Upon return the bits will be structured as:
PVOID ''pBuffer'' (output)
:* '''32-16''' The number of bytes that were in the pipe. This includes message-header bytes and bytes that have been examined.
 
:* '''15-0''' The number of bytes in the current message. This will be 0 for a byte-stream pipe.
This is a pointer to a output buffer.
;PULONG ''pPipeState'' (input):This is a pointer to a value, representing the state of the named pipe.
 
:* A value of 1 (NP_STATE_DISCONNECTED) means disconnected.
 
:* A value of 2 (NP_STATE_LISTENING) means listening.
ULONG ''ulBufferLen'' (input)
:* A value of 3 (NP_STATE_CONNECTED) means connected.
 
:* A value of 4 (NP_STATE_CLOSING) means closing.
The number of bytes to read.
 
 
PULONG ''pBytesRead'' (output)
 
A pointer to a variable that will contain the number of bytes actually read.
 
 
PAVAILDATA ''pBytesAvail'' (output)
 
This is a pointer to a 4-byte buffer. Upon return the bits will be
structured as:
 
* '''32-16''' The number of bytes that were in the pipe. This includes
message-header bytes and bytes that have been examined.
* '''15-0''' The number of bytes in the current message. This will be 0
for a byte-stream pipe.
 
 
PULONG ''pPipeState'' (input)
This is a pointer to a value, representing the state of the named pipe.
 
* A value of 1 (NP_STATE_DISCONNECTED) means disconnected.
* A value of 2 (NP_STATE_LISTENING) means listening.
* A value of 3 (NP_STATE_CONNECTED) means connected.
* A value of 4 (NP_STATE_CLOSING) means closing.


A pipe is in disconnected state immediately after [[OS2 API:CPI:DosCreateNPipe|DosCreateNPipe]] or [[OS2 API:CPI:DosDisConnectNPipe|DosDisConnectNPipe]]. A pipe that is
A pipe is in disconnected state immediately after [[DosCreateNPipe]] or [[DosDisConnectNPipe]]. A pipe that is disconnected can not be opened using [[DosOpen]].
disconnected can not be opened using [[OS2 API:CPI:DosOpen|DosOpen]].


A pipe is in the listening state after the server has called [[DosConnectNPipe]]. [[DosOpen]] may be called on a pipe that is listening.


A pipe is in the listening state after the server has called [[OS2 API:CPI:DosConnectNPipe|DosConnectNPipe]]. [[OS2 API:CPI:DosOpen|DosOpen]] may be called on a pipe that is listening.
A pipe is connected when a client has used [[DosOpen]] on it. This will allow, providing they
have valid handles, the client and the server to read and write data to the pipe.


 
A pipe is closing when all client ends have been closed, using [[DosClose]]. The server end should then acknowledge this (the pipe is now in closing state) by issuing [[DosDisConnectNPipe]] or [[DosClose]].
A pipe is connected when a client has used [[OS2 API:CPI:DosOpen|DosOpen]] on it. This will allow, providing they
have valid handles, the client and the server to read and write data to the ipe.
 
 
A pipe is closing when all client ends have been closed, using [[OS2 API:CPI:DosClose|DosClose]]. The server end should then acknowledge this (the pipe is now in closing state) by issuing [[OS2 API:CPI:DosDisConnectNPipe|DosDisConnectNPipe]] or [[OS2 API:CPI:DosClose|DosClose]].


=== Returns ===
=== Returns ===
  APIRET rc
APIRET rc
The following values can be returned
The following values can be returned    
     
{| border="1"
{| border="1"
|-
|0
|0
|NO_ERROR
|NO_ERROR
Line 78: Line 45:
|233
|233
|ERROR_PIPE_NOT_CONNECTED
|ERROR_PIPE_NOT_CONNECTED
|}
|}
 
=== Include Info ===
=== Include Info ===
  #define INCL_DOSNMPIPES
  #define INCL_DOSNMPIPES
  #include <os2.h>
  #include <os2.h>
 


=== Usage Explanation ===
=== Usage Explanation ===
DosPeekNPipe will examine the content and status of the pipe, without changing the pipe in any way (contents and state remain).


DosPeekNPipe will examine the content and status of the pipe, without
DosPeekNPipe will never block. If DosPeekNPipe can't get access to the pipe at once, it will return ERROR_PIPE_BUSY. Because of this it will return what's currently in the buffer, even though this might not be a complete message.
changing the pipe in any way (contents and state remain).
 
 
DosPeekNPipe will never block. If DosPeekNPipe can't get access to the
pipe at once, it will return ERROR_PIPE_BUSY. Because of this it will
return what's currently in the buffer, even though this might not be a
complete message.
 


=== Relevant Structures ===
=== Relevant Structures ===
Line 105: Line 64:
} AVAILDATA;
} AVAILDATA;
</pre>
</pre>
=== Gotchas ===
 
=== Sample Code ===
=== Sample Code ===
<pre>  
<pre>  
Line 112: Line 70:
#include  
#include  


HPIPE Handle;
HPIPE Handle;      /* The pipe handle. */
       /* The pipe handle. */
UCHAR Buffer[800]; /* The user buffer. */
 
ULONG BufferLen;   /* The length of the buffer. */
UCHAR Buffer[800];
ULONG BytesRead;   /* The actual number of bytes read. */
      /* The user buffer. */
 
ULONG BufferLen;
      /* The length of the buffer. */
 
ULONG BytesRead;
      /* The actual number of bytes read. */


struct _AVAILDATA BytesAvail;
struct _AVAILDATA BytesAvail; /* Bytes available. */
      /* Bytes available. */


ULONG PipeState;
ULONG PipeState; /* The returned pipestate. */
      /* The returned pipestate. */


APIRET rc;
APIRET rc;      /* Just to take care of the return code. */
       /* Just to take care of the return code. */


Bufferlen = 800;
Bufferlen = 800; /* Length of the buffer we read into. */
      /* Length of the buffer we read into. */


rc = DosPeekNPipe( Handle, Buffer, BufferLen, &BytesRead,
rc = DosPeekNPipe( Handle, Buffer, BufferLen, &BytesRead,
Line 144: Line 91:
}
}
</pre>
</pre>
=== See Also ===
=== See Also ===
[[OS2 API:CPI:DosConnectNPipe|DosConnectNPipe]],
*[[DosConnectNPipe]]
[[OS2 API:CPI:DosCreateNPipe|DosCreateNPipe]],
*[[DosCreateNPipe]]
[[OS2 API:CPI:DosDisConnectNPipe|DosDisConnectNPipe]],
*[[DosDisConnectNPipe]]
[[OS2 API:CPI:DosCallNPipe|DosCallNPipe]],
*[[DosCallNPipe]]
[[OS2 API:CPI:DosQueryNPHState|DosQueryNPHState]],
*[[DosQueryNPHState]]
[[OS2 API:CPI:DosQueryNPipeInfo|DosQueryNPipeInfo]],
*[[DosQueryNPipeInfo]]
[[OS2 API:CPI:DosQueryNPipeSemState|DosQueryNPipeSemState]],
*[[DosQueryNPipeSemState]]
[[OS2 API:CPI:DosSetNPHState|DosSetNPHState]],
*[[DosSetNPHState]]
[[OS2 API:CPI:DosSetNPipeSem|DosSetNPipeSem]],
*[[DosSetNPipeSem]]
[[OS2 API:CPI:DosTransactNPipe|DosTransactNPipe]],
*[[DosTransactNPipe]]
[[OS2 API:CPI:DosWaitNPipe|DosWaitNPipe]],
*[[DosWaitNPipe]]
[[OS2 API:CPI:DosClose|DosClose]],
*[[DosClose]]
[[OS2 API:CPI:DosDupHandle|DosDupHandle]],
*[[DosDupHandle]]
[[OS2 API:CPI:DosOpen|DosOpen]],
*[[DosOpen]]
[[OS2 API:CPI:DosRead|DosRead]],
*[[DosRead]]
[[OS2 API:CPI:DosResetBuffer|DosResetBuffer]],
*[[DosResetBuffer]]
[[OS2 API:CPI:DosWrite|DosWrite]]  
*[[DosWrite]]
 


[[Category:The OS/2 API Project]]
[[Category:Dos]]

Revision as of 21:15, 14 December 2016

Syntax

rc = DosPeekNPipe( hpipeHandle, 
                   pBuffer, 
                   ulBufferLen, 
                   pBytesRead,
                   pBytesAvail, 
                   pPipeState );

Parameters

HPIPE hpipeHandle (input)
Handle of the named pipe to examine. It is returned by DosCreateNPipe (for the server) or DosOpen (for the client).
PVOID pBuffer (output)
This is a pointer to a output buffer.
ULONG ulBufferLen (input)
The number of bytes to read.
PULONG pBytesRead (output)
A pointer to a variable that will contain the number of bytes actually read.
PAVAILDATA pBytesAvail (output)
This is a pointer to a 4-byte buffer. Upon return the bits will be structured as:
  • 32-16 The number of bytes that were in the pipe. This includes message-header bytes and bytes that have been examined.
  • 15-0 The number of bytes in the current message. This will be 0 for a byte-stream pipe.
PULONG pPipeState (input)
This is a pointer to a value, representing the state of the named pipe.
  • A value of 1 (NP_STATE_DISCONNECTED) means disconnected.
  • A value of 2 (NP_STATE_LISTENING) means listening.
  • A value of 3 (NP_STATE_CONNECTED) means connected.
  • A value of 4 (NP_STATE_CLOSING) means closing.

A pipe is in disconnected state immediately after DosCreateNPipe or DosDisConnectNPipe. A pipe that is disconnected can not be opened using DosOpen.

A pipe is in the listening state after the server has called DosConnectNPipe. DosOpen may be called on a pipe that is listening.

A pipe is connected when a client has used DosOpen on it. This will allow, providing they have valid handles, the client and the server to read and write data to the pipe.

A pipe is closing when all client ends have been closed, using DosClose. The server end should then acknowledge this (the pipe is now in closing state) by issuing DosDisConnectNPipe or DosClose.

Returns

APIRET rc

The following values can be returned

0 NO_ERROR
230 ERROR_BAD_PIPE
231 ERROR_PIPE_BUSY
233 ERROR_PIPE_NOT_CONNECTED

Include Info

#define INCL_DOSNMPIPES
#include <os2.h>

Usage Explanation

DosPeekNPipe will examine the content and status of the pipe, without changing the pipe in any way (contents and state remain).

DosPeekNPipe will never block. If DosPeekNPipe can't get access to the pipe at once, it will return ERROR_PIPE_BUSY. Because of this it will return what's currently in the buffer, even though this might not be a complete message.

Relevant Structures

typedef struct _AVAILDATA
{
   USHORT cbpipe;      /* bytes left in pipe. */
   USHORT cbmessage;   /* bytes left in current message. */
} AVAILDATA;

Sample Code

 
#define INCL_DOSNMPIPES
#include 

HPIPE Handle;       /* The pipe handle. */
UCHAR Buffer[800];  /* The user buffer. */
ULONG BufferLen;    /* The length of the buffer. */
ULONG BytesRead;    /* The actual number of bytes read. */

struct _AVAILDATA BytesAvail; /* Bytes available. */

ULONG PipeState; /* The returned pipestate. */

APIRET rc;       /* Just to take care of the return code. */

Bufferlen = 800; /* Length of the buffer we read into. */

rc = DosPeekNPipe( Handle, Buffer, BufferLen, &BytesRead,
         &BytesAvail, &PipeState);

if (rc != 0)
{
   /* We have an error we must take care of. */
}

See Also