Jump to content

DosCreateNPipe: Difference between revisions

From EDM2
Ak120 (talk | contribs)
No edit summary
Line 1: Line 1:
DosCreateNPipe is used to create a named pipe.
=== Syntax ===
=== Syntax ===
  rc = DosCreateNPipe( ''pszFileName'',  
  rc = DosCreateNPipe( ''pszFileName'',  
                       ''phpipePipeHandle'',  
                       ''phpipePipeHandle'',  
Line 8: Line 9:
                       ''ulInBufSize'',  
                       ''ulInBufSize'',  
                       ''ulTimeOut'' );
                       ''ulTimeOut'' );


=== Parameters ===
=== Parameters ===
PSZ ''pszFileName'' (input)
;PSZ ''pszFileName'' (input):The name, in ASCIIZ, of the pipe we are going to open. A valid name includes the prefix \PIPE\ and conforms to the naming conventions of the filesystem.
 
;PHPIPE ''phpipePipeHandle'' (output):This is a pointer to a variable that will recieve the handle of the created pipe.
The name, in ASCIIZ, of the pipe we are going to open. A valid name
;ULONG ''ulOpenMode'' (input):OpenMode contains the following bits:
includes the prefix \PIPE\ and conforms to the naming conventions of the
::'''31-16''' Reserved bits.
filesystem.
::'''15''' This is a reserved bit, and MUST be 0.
 
::'''14''' Write-through. A value of 0 equals NP_WRITEBEHIND (0x0000) and allows write-behind to remote pipes. A value of 1 equals NP_NOWRITEBEHIND (0x4000) does not allow write-behind to remote pipes. This bit is only meaningful for a remote pipe. It sometimes happens that data written to a remote byte is buffered and sent later to the pipe. Setting the write-through bit will make sure that the data is sent to the pipe as soon as it is written.
 
::'''13-8''' Reserved.
PHPIPE ''phpipePipeHandle'' (output)
::'''7''' Inheritance flag. A value of 0 equals NP_INHERIT (0x0000) and means that the pipe handle is inherited by a child process. A value of 1 equals NP_NOINHERIT (0x0080) and means that the handle is private to the process, and cannot be inherited. This bit is not inherited itself by child processes.
 
::'''6-3''' Reserved bits, and MUST be 0.
This is a pointer to a variable that will recieve the handle of the
::'''2-0''' Access mode. It is defined as:
created pipe.
:::000 - NP_ACCESS_INBOUND (0x0000). Inbound pipe (client to server).
 
:::001 - NP_ACCESS_OUTBOUND (0x0001). Outbound pipe (server to client).
 
:::010 - NP_ACCESS_DUPLEX (0x0002). Duplex pipe (server to and from client).
ULONG ''ulOpenMode'' (input)
:::All other values are invalid.
 
;ULONG ''ulPipeMode'' (input):Contains the following bits:
OpenMode contains the following bits:
::'''31-16''' Reserved.
 
::'''15''' Blockingmode. A value of 0 equals NP_WAIT (0x0000) and means blocking mode. [[DosRead]] and [[DosWrite]] will block if no data is available. A value of 1 equals NP_NOWAIT (0x8000) and means nonblocking mode. This will force [[DosRead]] and [[DosWrite]] to return at once if no data is available. In blocking mode [[DosRead]] will block until at least a part of the data can be returned. [[DosWrite]] will block until all the requested data has been written. In nonblocking mode this changes so that [[DosRead]] will return at once with the error ERROR_NO_DATA if no data is available. [[DosWrite]] will returns at once with BytesWritten set as 0, if the available bufferspace in the pipe is not sufficient for the data being written. Otherwise the entire data is written as normal.
 
::'''14-12''' Reserved.
'''31-16''' Reserved bits.
::'''11-10''' Type of named pipe. A value of 00 equals NP_TYPE_BYTE (0x0000). Data written to this pipe will be an undifferentiated stream of bytes. A value of 01 equals NP_TYPE_MESSAGE (0x0400). Data written here is written as messages, and the first two bytes of the message (called the message header) contains the size of the message. A header containing zeroes is reserved, and zero-length messages are not allowed.
 
::'''9-8''' Read mode. A value of 00 equals NP_READMODE_BYTE (0x0000) and means read the pipe as byte stream. A value of 01 equals NP_READMODE_MESSAGE (0x0100) and means read the pipe as a message stream. A pipe defined as a messagepipe can be read as both message stream or byte
 
stream, depending on the value of the read mode. If the pipe is a byte stream, it must be read as byte stream.
'''15''' This is a reserved bit, and MUST be 0.
::'''7-0''' Instance count. This defines the number of instances, including the first one, that may be created. A value of 1 means the pipe is unique, only one instance allowed. If the value is between, but not equal to, 1 and 255 this is the number of instances that may be created. A value of -1 equals NP_UNLIMITED_INSTANCES (0x00FF) and means that an unlimited number of instances may be created. A value of 0 is reserved. Allowing multiple instances allows multiple clients to connect to the same pipe at the same time.
 
;ULONG ''ulOutBufSize'' (input):This tells the system how many bytes it should allocate for the
 
'''14''' Write-through. A value of 0 equals NP_WRITEBEHIND (0x0000)
and allows write-behind to remote pipes. A value of 1 equals
NP_NOWRITEBEHIND (0x4000) does not allow write-behind to remote pipes.
This bit is only meaningful for a remote pipe. It sometimes happens that
data written to a remote byte is buffered and sent later to the pipe.
Setting the write-through bit will make sure that the data is sent to the
pipe as soon as it is written.
 
 
'''13-8''' Reserved.
 
 
'''7''' Inheritance flag. A value of 0 equals NP_INHERIT (0x0000) and
means that the pipe handle is inherited by a child process. A value of 1  
equals NP_NOINHERIT (0x0080) and means that the handle is private to the
process, and cannot be inherited. This bit is not inherited itself by
child processes.
 
 
'''6-3''' Reserved bits, and MUST be 0.
 
 
'''2-0''' Access mode. It is defined as:
 
 
000 - NP_ACCESS_INBOUND (0x0000). Inbound pipe (client to server).
 
 
001 - NP_ACCESS_OUTBOUND (0x0001). Outbound pipe (server to client).
 
 
010 - NP_ACCESS_DUPLEX (0x0002). Duplex pipe (server to and from client).
 
 
All other values are invalid.
 
 
ULONG ''ulPipeMode'' (input)
 
Contains the following bits:
 
 
'''31-16''' Reserved.
 
 
'''15''' Blockingmode. A value of 0 equals NP_WAIT (0x0000) and means
blocking mode. [[DosRead]] and
[[DosWrite]] will block if no data is available. A
value of 1 equals NP_NOWAIT (0x8000) and means nonblocking mode. This will
force [[DosRead]] and [[DosWrite]] to return at once if no data is
available. In blocking mode [[DosRead]] will block
until at least a part of the data can be returned. [[DosWrite]] will block until all the requested data
has been written. In nonblocking mode this changes so that [[DosRead]] will return at once with the error
ERROR_NO_DATA if no data is available. [[DosWrite]] will returns at once with BytesWritten
set as 0, if the available bufferspace in the pipe is not sufficient for
the data being written. Otherwise the entire data is written as normal.
 
 
'''14-12''' Reserved.
 
 
'''11-10''' Type of named pipe. A value of 00 equals NP_TYPE_BYTE
(0x0000). Data written to this pipe will be an undifferentiated stream of
bytes. A value of 01 equals NP_TYPE_MESSAGE (0x0400). Data written here
is written as messages, and the first two bytes of the message (called the
message header) contains the size of the message. A header containing
zeroes is reserved, and zero-length messages are not allowed.
 
 
'''9-8''' Read mode. A value of 00 equals NP_READMODE_BYTE (0x0000)
and means read the pipe as byte stream. A value of 01 equals
NP_READMODE_MESSAGE (0x0100) and means read the pipe as a message stream.
A pipe defined as a messagepipe can be read as both message stream or byte
stream, depending on the value of the read mode. If the pipe is a byte
stream, it must be read as byte stream.
 
 
'''7-0''' Instance count. This defines the number of instances,
including the first one, that may be created. A value of 1 means the pipe
is unique, only one instance allowed. If the value is between, but not
equal to, 1 and 255 this is the number of instances that may be created. A
value of -1 equals NP_UNLIMITED_INSTANCES (0x00FF) and means that an
unlimited number of instances may be created. A value of 0 is reserved.
Allowing multiple instances allows multiple clients to connect to the same
pipe at the same time.
 
 
ULONG ''ulOutBufSize'' (input)
 
This tells the system how many bytes it should allocate for the
outbound (server to client) buffer.
outbound (server to client) buffer.
;ULONG ''ulInBufSize'' (input):This tells the system how many bytes it should allocate for the inbound (client to server) buffer.
;ULONG ''ulTimeOut'' (input):This value may be set once only, when the first instance of the pipe is created. The value is the default value for the TimeOut parameter of [[DosWaitNPipe]], and if the value is 0, a default value of 50 (milliseconds) is used.


ULONG ''ulInBufSize'' (input)
This tells the system how many bytes it should allocate for the inbound
(client to server) buffer.
ULONG ''ulTimeOut'' (input)
This value may be set once only, when the first instance of the pipe is
created. The value is the default value for the TimeOut parameter of [[DosWaitNPipe]], and if the value is 0, a default
value of 50 (milliseconds) is used.
=== Returns ===
=== Returns ===
   APIRET rc
   APIRET rc
The following values can be returned
The following values can be returned      
       
{|class="wikitable"
{| border="1"
|-
|0
|0
|NO_ERROR
|NO_ERROR
Line 164: Line 59:
|231
|231
|ERROR_PIPE_BUSY
|ERROR_PIPE_BUSY
|}
|}
 
=== Include Info ===
=== Include Info ===
  #define INCL_DOSNMPIPES
  #define INCL_DOSNMPIPES
  #include <os2.h>
  #include <os2.h>
 
 
=== Usage Explanation ===
 
DosCreateNPipe is used to create a named pipe.
 
 
=== Relevant Structures ===
=== Gotchas ===
   
   
=== Sample Code ===
=== Sample Code ===
Line 186: Line 71:
#include  
#include  


UCHAR FileName[40];
UCHAR FileName[40]; /* The pipe name. */
      /* The pipe name. */
HPIPE PipeHandle;   /* The returned pipehandle will be stored here. */
 
ULONG OpenMode;     /* OpenMode parameters. */
HPIPE PipeHandle;
ULONG PipeMode;     /* Pipemode parameters. */
      /* The returned pipehandle will be stored here. */
ULONG OutBufSize;   /* Size of the outbuffer. */
 
ULONG InBufSize;     /* Size of the inbuffer. */
ULONG OpenMode;
ULONG TimeOut;      /* Default value for DosWaitNPipe timeout parameter. */
      /* OpenMode parameters. */
APIRET rc;           /* Just to take care of the return code. */
 
ULONG PipeMode;
      /* Pipemode parameters. */
 
ULONG OutBufSize;
      /* Size of the outbuffer. */
 
ULONG InBufSize;
      /* Size of the inbuffer. */
 
ULONG TimeOut;
       /* Default value for DosWaitNPipe timeout parameter. */
 
APIRET rc;
      /* Just to take care of the return code. */


strcpy(FileName, "\\PIPE\\MYPIPE");
strcpy(FileName, "\\PIPE\\MYPIPE");
Line 221: Line 91:
       /* Only one instance allowed at a time. */
       /* Only one instance allowed at a time. */


InBufSize = 2048;
InBufSize = 2048;   /* The size of the incoming data buffer. */
      /* The size of the incoming data buffer. */
OutBufSize = 2048;   /* The size of the outgoing data buffer. */
 
TimeOut = 1000;     /* Timeout is 1 second (1000 milliseconds). */
OutBufSize = 2048;
      /* The size of the outgoing data buffer. */
 
TimeOut = 1000;
      /* Timeout is 1 second (1000 milliseconds).


rc = DosCreateNPipe( FileName, &PipeHandle, OpenMode, PipeMode,
rc = DosCreateNPipe( FileName, &PipeHandle, OpenMode, PipeMode,
Line 240: Line 105:
   
   
=== See Also ===
=== See Also ===
[[OS2 API:CPI:DosCallNPipe|DosCallNPipe]],
*[[DosCallNPipe]]
[[OS2 API:CPI:DosConnectNPipe|DosConnectNPipe]],
*[[DosConnectNPipe]]
[[OS2 API:CPI:DosDisConnectNPipe|DosDisConnectNPipe]],
*[[DosDisConnectNPipe]]
[[OS2 API:CPI:DosPeekNPipe|DosPeekNPipe]],
*[[DosPeekNPipe]]
[[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 03:02, 11 December 2016

DosCreateNPipe is used to create a named pipe.

Syntax

rc = DosCreateNPipe( pszFileName, 
                     phpipePipeHandle, 
                     ulOpenMode, 
                     ulPipeMode,
                     ulOutBufSize, 
                     ulInBufSize, 
                     ulTimeOut );

Parameters

PSZ pszFileName (input)
The name, in ASCIIZ, of the pipe we are going to open. A valid name includes the prefix \PIPE\ and conforms to the naming conventions of the filesystem.
PHPIPE phpipePipeHandle (output)
This is a pointer to a variable that will recieve the handle of the created pipe.
ULONG ulOpenMode (input)
OpenMode contains the following bits:
31-16 Reserved bits.
15 This is a reserved bit, and MUST be 0.
14 Write-through. A value of 0 equals NP_WRITEBEHIND (0x0000) and allows write-behind to remote pipes. A value of 1 equals NP_NOWRITEBEHIND (0x4000) does not allow write-behind to remote pipes. This bit is only meaningful for a remote pipe. It sometimes happens that data written to a remote byte is buffered and sent later to the pipe. Setting the write-through bit will make sure that the data is sent to the pipe as soon as it is written.
13-8 Reserved.
7 Inheritance flag. A value of 0 equals NP_INHERIT (0x0000) and means that the pipe handle is inherited by a child process. A value of 1 equals NP_NOINHERIT (0x0080) and means that the handle is private to the process, and cannot be inherited. This bit is not inherited itself by child processes.
6-3 Reserved bits, and MUST be 0.
2-0 Access mode. It is defined as:
000 - NP_ACCESS_INBOUND (0x0000). Inbound pipe (client to server).
001 - NP_ACCESS_OUTBOUND (0x0001). Outbound pipe (server to client).
010 - NP_ACCESS_DUPLEX (0x0002). Duplex pipe (server to and from client).
All other values are invalid.
ULONG ulPipeMode (input)
Contains the following bits:
31-16 Reserved.
15 Blockingmode. A value of 0 equals NP_WAIT (0x0000) and means blocking mode. DosRead and DosWrite will block if no data is available. A value of 1 equals NP_NOWAIT (0x8000) and means nonblocking mode. This will force DosRead and DosWrite to return at once if no data is available. In blocking mode DosRead will block until at least a part of the data can be returned. DosWrite will block until all the requested data has been written. In nonblocking mode this changes so that DosRead will return at once with the error ERROR_NO_DATA if no data is available. DosWrite will returns at once with BytesWritten set as 0, if the available bufferspace in the pipe is not sufficient for the data being written. Otherwise the entire data is written as normal.
14-12 Reserved.
11-10 Type of named pipe. A value of 00 equals NP_TYPE_BYTE (0x0000). Data written to this pipe will be an undifferentiated stream of bytes. A value of 01 equals NP_TYPE_MESSAGE (0x0400). Data written here is written as messages, and the first two bytes of the message (called the message header) contains the size of the message. A header containing zeroes is reserved, and zero-length messages are not allowed.
9-8 Read mode. A value of 00 equals NP_READMODE_BYTE (0x0000) and means read the pipe as byte stream. A value of 01 equals NP_READMODE_MESSAGE (0x0100) and means read the pipe as a message stream. A pipe defined as a messagepipe can be read as both message stream or byte

stream, depending on the value of the read mode. If the pipe is a byte stream, it must be read as byte stream.

7-0 Instance count. This defines the number of instances, including the first one, that may be created. A value of 1 means the pipe is unique, only one instance allowed. If the value is between, but not equal to, 1 and 255 this is the number of instances that may be created. A value of -1 equals NP_UNLIMITED_INSTANCES (0x00FF) and means that an unlimited number of instances may be created. A value of 0 is reserved. Allowing multiple instances allows multiple clients to connect to the same pipe at the same time.
ULONG ulOutBufSize (input)
This tells the system how many bytes it should allocate for the

outbound (server to client) buffer.

ULONG ulInBufSize (input)
This tells the system how many bytes it should allocate for the inbound (client to server) buffer.
ULONG ulTimeOut (input)
This value may be set once only, when the first instance of the pipe is created. The value is the default value for the TimeOut parameter of DosWaitNPipe, and if the value is 0, a default value of 50 (milliseconds) is used.

Returns

 APIRET rc

The following values can be returned

0 NO_ERROR
3 ERROR_PATH_NOT_FOUND
8 ERROR_NOT_ENOUGH_MEMORY
84 ERROR_OUT_OF_STRUCTURES
87 ERROR_INVALID_PARAMETER
231 ERROR_PIPE_BUSY

Include Info

#define INCL_DOSNMPIPES
#include <os2.h>

Sample Code

#define INCL_DOSNMPIPES
#include 
#include 

UCHAR FileName[40];  /* The pipe name. */
HPIPE PipeHandle;    /* The returned pipehandle will be stored here. */
ULONG OpenMode;      /* OpenMode parameters. */
ULONG PipeMode;      /* Pipemode parameters. */
ULONG OutBufSize;    /* Size of the outbuffer. */
ULONG InBufSize;     /* Size of the inbuffer. */
ULONG TimeOut;       /* Default value for DosWaitNPipe timeout parameter. */
APIRET rc;           /* Just to take care of the return code. */

strcpy(FileName, "\\PIPE\\MYPIPE");

OpenMode = NP_ACCESS_DUPLEX;
      /* Duplex access to the pipe, no child process inheritance. */
      /* Write-through is of no concern since it only affects */
      /* remote pipes. */

PipeMode = 0x01 | NP_RMESG | NP_WMESG;
      /* Blocking mode. Message streams for both read and write. */
      /* Only one instance allowed at a time. */

InBufSize = 2048;    /* The size of the incoming data buffer. */
OutBufSize = 2048;   /* The size of the outgoing data buffer. */
TimeOut = 1000;      /* Timeout is 1 second (1000 milliseconds). */

rc = DosCreateNPipe( FileName, &PipeHandle, OpenMode, PipeMode,
         OutBufSize, InBufSize, TimeOut);

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

See Also