jwalmapibuf.pas 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. {******************************************************************************}
  2. { }
  3. { Lan Manager Buffer 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: lmapibuf.h, released November 2001. The original }
  9. { Pascal code is: LmApiBuf.pas, released Februari 2002. The initial developer }
  10. { of the 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: JwaLmApiBuf.pas,v 1.9 2005/09/07 09:54:54 marquardt Exp $
  43. {$IFNDEF JWA_INCLUDEMODE}
  44. unit JwaLmApiBuf;
  45. {$WEAKPACKAGEUNIT}
  46. {$I jediapilib.inc}
  47. interface
  48. uses
  49. JwaWindows, JwaLmCons;
  50. {$ENDIF !JWA_INCLUDEMODE}
  51. {$IFDEF JWA_INTERFACESECTION}
  52. {$HPPEMIT ''}
  53. {$HPPEMIT '#include "lmapibuf.h"'}
  54. {$HPPEMIT ''}
  55. //
  56. // Function Prototypes
  57. //
  58. function NetApiBufferAllocate(ByteCount: DWORD; var Buffer: LPVOID): NET_API_STATUS; stdcall;
  59. {$EXTERNALSYM NetApiBufferAllocate}
  60. function NetApiBufferFree(Buffer: LPVOID): NET_API_STATUS; stdcall;
  61. {$EXTERNALSYM NetApiBufferFree}
  62. function NetApiBufferReallocate(OldBuffer: LPVOID; NewByteCount: DWORD; var NewBuffer: LPVOID): NET_API_STATUS; stdcall;
  63. {$EXTERNALSYM NetApiBufferReallocate}
  64. function NetApiBufferSize(Buffer: LPVOID; var ByteCount: DWORD): NET_API_STATUS; stdcall;
  65. {$EXTERNALSYM NetApiBufferSize}
  66. //
  67. // The following private function will go away eventually.
  68. // Call NetApiBufferAllocate instead.
  69. //
  70. function NetapipBufferAllocate(ByteCount: DWORD; var Buffer: LPVOID): NET_API_STATUS; stdcall;
  71. {$EXTERNALSYM NetapipBufferAllocate}
  72. {$ENDIF JWA_INTERFACESECTION}
  73. {$IFNDEF JWA_INCLUDEMODE}
  74. implementation
  75. uses
  76. JwaWinDLLNames;
  77. {$ENDIF !JWA_INCLUDEMODE}
  78. {$IFDEF JWA_IMPLEMENTATIONSECTION}
  79. {$IFDEF DYNAMIC_LINK}
  80. var
  81. _NetApiBufferAllocate: Pointer;
  82. function NetApiBufferAllocate;
  83. begin
  84. GetProcedureAddress(_NetApiBufferAllocate, netapi32, 'NetApiBufferAllocate');
  85. asm
  86. MOV ESP, EBP
  87. POP EBP
  88. JMP [_NetApiBufferAllocate]
  89. end;
  90. end;
  91. var
  92. _NetApiBufferFree: Pointer;
  93. function NetApiBufferFree;
  94. begin
  95. GetProcedureAddress(_NetApiBufferFree, netapi32, 'NetApiBufferFree');
  96. asm
  97. MOV ESP, EBP
  98. POP EBP
  99. JMP [_NetApiBufferFree]
  100. end;
  101. end;
  102. var
  103. _NetApiBufferReallocate: Pointer;
  104. function NetApiBufferReallocate;
  105. begin
  106. GetProcedureAddress(_NetApiBufferReallocate, netapi32, 'NetApiBufferReallocate');
  107. asm
  108. MOV ESP, EBP
  109. POP EBP
  110. JMP [_NetApiBufferReallocate]
  111. end;
  112. end;
  113. var
  114. _NetApiBufferSize: Pointer;
  115. function NetApiBufferSize;
  116. begin
  117. GetProcedureAddress(_NetApiBufferSize, netapi32, 'NetApiBufferSize');
  118. asm
  119. MOV ESP, EBP
  120. POP EBP
  121. JMP [_NetApiBufferSize]
  122. end;
  123. end;
  124. var
  125. _NetapipBufferAllocate: Pointer;
  126. function NetapipBufferAllocate;
  127. begin
  128. GetProcedureAddress(_NetapipBufferAllocate, netapi32, 'NetapipBufferAllocate');
  129. asm
  130. MOV ESP, EBP
  131. POP EBP
  132. JMP [_NetapipBufferAllocate]
  133. end;
  134. end;
  135. {$ELSE}
  136. function NetApiBufferAllocate; external netapi32 name 'NetApiBufferAllocate';
  137. function NetApiBufferFree; external netapi32 name 'NetApiBufferFree';
  138. function NetApiBufferReallocate; external netapi32 name 'NetApiBufferReallocate';
  139. function NetApiBufferSize; external netapi32 name 'NetApiBufferSize';
  140. function NetapipBufferAllocate; external netapi32 name 'NetapipBufferAllocate';
  141. {$ENDIF DYNAMIC_LINK}
  142. {$ENDIF JWA_IMPLEMENTATIONSECTION}
  143. {$IFNDEF JWA_INCLUDEMODE}
  144. end.
  145. {$ENDIF !JWA_INCLUDEMODE}