jwawsvns.pas 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. {******************************************************************************}
  2. { }
  3. { Winsock2 Vines IP API interface Unit for Object Pascal }
  4. { }
  5. { Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft }
  6. { Corporation. All Rights Reserved. }
  7. { }
  8. { The original file is: wsvns.h, released June 2000. The original Pascal }
  9. { code is: WSvns.pas, released December 2000. The initial developer of the }
  10. { Pascal code is Marcel van Brakel (brakelm att chello dott nl). }
  11. { }
  12. { Portions created by Marcel van Brakel are Copyright (C) 1999-2001 }
  13. { Marcel van Brakel. All Rights Reserved. }
  14. { }
  15. { Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI) }
  16. { }
  17. { You may retrieve the latest version of this file at the Project JEDI }
  18. { APILIB home page, located at http://jedi-apilib.sourceforge.net }
  19. { }
  20. { The contents of this file are used with permission, subject to the Mozilla }
  21. { Public License Version 1.1 (the "License"); you may not use this file except }
  22. { in compliance with the License. You may obtain a copy of the License at }
  23. { http://www.mozilla.org/MPL/MPL-1.1.html }
  24. { }
  25. { Software distributed under the License is distributed on an "AS IS" basis, }
  26. { WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }
  27. { the specific language governing rights and limitations under the License. }
  28. { }
  29. { Alternatively, the contents of this file may be used under the terms of the }
  30. { GNU Lesser General Public License (the "LGPL License"), in which case the }
  31. { provisions of the LGPL License are applicable instead of those above. }
  32. { If you wish to allow use of your version of this file only under the terms }
  33. { of the LGPL License and not to allow others to use your version of this file }
  34. { under the MPL, indicate your decision by deleting the provisions above and }
  35. { replace them with the notice and other provisions required by the LGPL }
  36. { License. If you do not delete the provisions above, a recipient may use }
  37. { your version of this file under either the MPL or the LGPL License. }
  38. { }
  39. { For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
  40. { }
  41. {******************************************************************************}
  42. // $Id: JwaWSvns.pas,v 1.4 2004/12/08 08:18:40 marquardt Exp $
  43. unit JwaWSvns;
  44. {$WEAKPACKAGEUNIT}
  45. {$HPPEMIT ''}
  46. {$HPPEMIT '#include "wsvns.h"'}
  47. {$HPPEMIT ''}
  48. {$I jediapilib.inc}
  49. interface
  50. uses
  51. JwaWinSock2;
  52. //
  53. // Windows Sockets include file for VINES IP. This file contains all
  54. // standardized VINES IP information. Include this header file after winsock.h.
  55. //
  56. // To open an VINES IP socket, call socket() with an address family of AF_BAN, a
  57. // socket type of SOCK_DGRAM, SOCK_STREAM, or SOCK_SEQPACKET, and protocol of 0.
  58. //
  59. //
  60. // Socket address, VINES IP style. Address fields and port field are defined
  61. // as a sequence of bytes. This is done because they are byte ordered
  62. // BIG ENDIAN, ala most significant byte first.
  63. //
  64. type
  65. SOCKADDR_VNS = record
  66. sin_family: u_short; // = AF_BAN
  67. net_address: array [0..3] of u_char; // network address
  68. subnet_addr: array [0..1] of u_char; // subnet address
  69. port: array [0..1] of u_char; // msb=port[0], lsb=port[1]
  70. hops: u_char; // # hops for broadcasts
  71. filler: array [0..4] of u_char; // filler, zeros
  72. end;
  73. {$EXTERNALSYM SOCKADDR_VNS}
  74. PSOCKADDR_VNS = ^SOCKADDR_VNS;
  75. {$EXTERNALSYM PSOCKADDR_VNS}
  76. LPSOCKADDR_VNS = ^SOCKADDR_VNS;
  77. {$EXTERNALSYM LPSOCKADDR_VNS}
  78. TSockAddrVNS = SOCKADDR_VNS;
  79. PSockAddrVNS = LPSOCKADDR_VNS;
  80. const
  81. VNSPROTO_IPC = 1;
  82. {$EXTERNALSYM VNSPROTO_IPC}
  83. VNSPROTO_RELIABLE_IPC = 2;
  84. {$EXTERNALSYM VNSPROTO_RELIABLE_IPC}
  85. VNSPROTO_SPP = 3;
  86. {$EXTERNALSYM VNSPROTO_SPP}
  87. implementation
  88. end.