jwawsnetbs.pas 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. {******************************************************************************}
  2. { }
  3. { Winsock2 Netbios 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: wsnetbs.h, released June 2000. The original Pascal }
  9. { code is: WSnetbs.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 JwaWSnetbs;
  43. {$WEAKPACKAGEUNIT}
  44. {$HPPEMIT ''}
  45. {$HPPEMIT '#include "wsnetbs.h"'}
  46. {$HPPEMIT ''}
  47. {$I jediapilib.inc}
  48. interface
  49. uses
  50. JwaWinSock2;
  51. //
  52. // wsnetbs.h
  53. // Copyright (c) 1994-1999, Microsoft Corp. All rights reserved.
  54. //
  55. // Windows Sockets include file for NETBIOS. This file contains all
  56. // standardized NETBIOS information. Include this header file after
  57. // winsock.h.
  58. //
  59. //
  60. // This is the structure of the SOCKADDR structure for NETBIOS.
  61. //
  62. const
  63. NETBIOS_NAME_LENGTH = 16;
  64. {$EXTERNALSYM NETBIOS_NAME_LENGTH}
  65. type
  66. SOCKADDR_NB = record
  67. snb_family: Smallint;
  68. snb_type: Word;
  69. snb_name: array [0..NETBIOS_NAME_LENGTH - 1] of Char;
  70. end;
  71. {$EXTERNALSYM SOCKADDR_NB}
  72. PSOCKADDR_NB = ^SOCKADDR_NB;
  73. {$EXTERNALSYM PSOCKADDR_NB}
  74. LPSOCKADDR_NB = ^SOCKADDR_NB;
  75. {$EXTERNALSYM LPSOCKADDR_NB}
  76. TSockAddrNB = SOCKADDR_NB;
  77. PSockAddrNB = LPSOCKADDR_NB;
  78. //
  79. // Bit values for the snb_type field of SOCKADDR_NB.
  80. //
  81. const
  82. NETBIOS_UNIQUE_NAME = $0000;
  83. {$EXTERNALSYM NETBIOS_UNIQUE_NAME}
  84. NETBIOS_GROUP_NAME = $0001;
  85. {$EXTERNALSYM NETBIOS_GROUP_NAME}
  86. NETBIOS_TYPE_QUICK_UNIQUE = $0002;
  87. {$EXTERNALSYM NETBIOS_TYPE_QUICK_UNIQUE}
  88. NETBIOS_TYPE_QUICK_GROUP = $0003;
  89. {$EXTERNALSYM NETBIOS_TYPE_QUICK_GROUP}
  90. //
  91. // A macro convenient for setting up NETBIOS SOCKADDRs.
  92. //
  93. procedure SET_NETBIOS_SOCKADDR(var SNB: TSockAddrNB; _Type: u_short; const Name: string; Port: Byte);
  94. {$EXTERNALSYM SET_NETBIOS_SOCKADDR}
  95. //
  96. // To open a NetBIOS socket, call the socket() function as follows:
  97. //
  98. // s = socket( AF_NETBIOS, {SOCK_SEQPACKET|SOCK_DGRAM}, -Lana );
  99. //
  100. // where Lana is the NetBIOS Lana number of interest. For example, to
  101. // open a socket for Lana 2, specify -2 as the "protocol" parameter
  102. // to the socket() function.
  103. //
  104. implementation
  105. procedure SET_NETBIOS_SOCKADDR(var SNB: TSockAddrNB; _Type: u_short; const Name: string; Port: Byte);
  106. var
  107. I: Integer;
  108. begin
  109. SNB.snb_family := AF_NETBIOS;
  110. SNB.snb_type := _Type;
  111. for I := 0 to NETBIOS_NAME_LENGTH - 1 do
  112. SNB.snb_name[I] := ' ';
  113. I := 0;
  114. while I < NETBIOS_NAME_LENGTH - 1 do
  115. begin
  116. if SNB.snb_name[I] = #0 then
  117. Break;
  118. SNB.snb_name[I] := SNB.snb_name[I + 1];
  119. Inc(I);
  120. end;
  121. SNB.snb_name[NETBIOS_NAME_LENGTH - 1] := Char(Port);
  122. end;
  123. end.