jwawsvns.pas 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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. unit JwaWSvns;
  43. {$WEAKPACKAGEUNIT}
  44. {$HPPEMIT ''}
  45. {$HPPEMIT '#include "wsvns.h"'}
  46. {$HPPEMIT ''}
  47. {$I jediapilib.inc}
  48. interface
  49. uses
  50. JwaWinSock2;
  51. //
  52. // Windows Sockets include file for VINES IP. This file contains all
  53. // standardized VINES IP information. Include this header file after winsock.h.
  54. //
  55. // To open an VINES IP socket, call socket() with an address family of AF_BAN, a
  56. // socket type of SOCK_DGRAM, SOCK_STREAM, or SOCK_SEQPACKET, and protocol of 0.
  57. //
  58. //
  59. // Socket address, VINES IP style. Address fields and port field are defined
  60. // as a sequence of bytes. This is done because they are byte ordered
  61. // BIG ENDIAN, ala most significant byte first.
  62. //
  63. type
  64. SOCKADDR_VNS = record
  65. sin_family: u_short; // = AF_BAN
  66. net_address: array [0..3] of u_char; // network address
  67. subnet_addr: array [0..1] of u_char; // subnet address
  68. port: array [0..1] of u_char; // msb=port[0], lsb=port[1]
  69. hops: u_char; // # hops for broadcasts
  70. filler: array [0..4] of u_char; // filler, zeros
  71. end;
  72. {$EXTERNALSYM SOCKADDR_VNS}
  73. PSOCKADDR_VNS = ^SOCKADDR_VNS;
  74. {$EXTERNALSYM PSOCKADDR_VNS}
  75. LPSOCKADDR_VNS = ^SOCKADDR_VNS;
  76. {$EXTERNALSYM LPSOCKADDR_VNS}
  77. TSockAddrVNS = SOCKADDR_VNS;
  78. PSockAddrVNS = LPSOCKADDR_VNS;
  79. const
  80. VNSPROTO_IPC = 1;
  81. {$EXTERNALSYM VNSPROTO_IPC}
  82. VNSPROTO_RELIABLE_IPC = 2;
  83. {$EXTERNALSYM VNSPROTO_RELIABLE_IPC}
  84. VNSPROTO_SPP = 3;
  85. {$EXTERNALSYM VNSPROTO_SPP}
  86. implementation
  87. end.