jwawsnetbs.pas 5.6 KB

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