jwaprotocol.pas 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. {******************************************************************************}
  2. { }
  3. { Winsock2 Protocol Definitions 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: protocol.h, released June 2000. The original Pascal }
  9. { code is: Protocol.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 JwaProtocol;
  43. {$WEAKPACKAGEUNIT}
  44. {$HPPEMIT ''}
  45. {$HPPEMIT '#include "protocol.h"'}
  46. {$HPPEMIT ''}
  47. {$I jediapilib.inc}
  48. interface
  49. uses
  50. {$IFDEF USE_DELPHI_TYPES}
  51. Windows;
  52. {$ELSE}
  53. JwaWinType;
  54. {$ENDIF USE_DELPHI_TYPES}
  55. type
  56. ETHERNET_ADDRESS = array [0..5] of BYTE;
  57. {$EXTERNALSYM ETHERNET_ADDRESS}
  58. ETHERNET_FRAME = record
  59. Destination: ETHERNET_ADDRESS;
  60. Source: ETHERNET_ADDRESS;
  61. FrameType: WORD; // in host-order
  62. end;
  63. {$EXTERNALSYM ETHERNET_FRAME}
  64. TEthernetFrame = ETHERNET_FRAME;
  65. PEthernetFrame = ^TEthernetFrame;
  66. const
  67. ETHERNET_FRAME_TYPE_IP = $0800;
  68. {$EXTERNALSYM ETHERNET_FRAME_TYPE_IP}
  69. type
  70. IP_HEADER = record
  71. x: BYTE;
  72. tos: BYTE;
  73. length: WORD;
  74. identifier: WORD;
  75. fragment: WORD;
  76. ttl: BYTE;
  77. protocol: BYTE;
  78. cksum: WORD;
  79. src: DWORD;
  80. dest: DWORD;
  81. end;
  82. {$EXTERNALSYM IP_HEADER}
  83. LPIP_HEADER = ^IP_HEADER;
  84. {$EXTERNALSYM LPIP_HEADER}
  85. TIPHeader = IP_HEADER;
  86. PIPHeader = LPIP_HEADER;
  87. const
  88. IP_MF = $2000;
  89. {$EXTERNALSYM IP_MF}
  90. IP_FRAGMENT_OFFSET_MASK = $1FFF;
  91. {$EXTERNALSYM IP_FRAGMENT_OFFSET_MASK}
  92. IP_HEADER_MINIMUM_LEN = 20;
  93. {$EXTERNALSYM IP_HEADER_MINIMUM_LEN}
  94. type
  95. UDP_HEADER = record
  96. src_port: WORD;
  97. dest_port: WORD;
  98. length: WORD; // including this header
  99. checksum: WORD;
  100. end;
  101. {$EXTERNALSYM UDP_HEADER}
  102. TUDPHeader = UDP_HEADER;
  103. PUDPHeader = ^TUDPHeader;
  104. const
  105. UDP_HEADER_LEN = 8;
  106. {$EXTERNALSYM UDP_HEADER_LEN}
  107. implementation
  108. end.