JwaLmApiBuf.pas
上传用户:davidchvip
上传日期:2009-07-28
资源大小:1749k
文件大小:6k
源码类别:

Windows编程

开发平台:

Delphi

  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 Pascal}
  9. { code is: LmApiBuf.pas, released Februari 2002. The initial developer of the }
  10. { Pascal code is Marcel van Brakel (brakelm@chello.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 home    }
  18. { page, located at http://delphi-jedi.org or my personal homepage located at   }
  19. { http://members.chello.nl/m.vanbrakel2                                        }
  20. {                }
  21. { The contents of this file are used with permission, subject to the Mozilla   }
  22. { Public License Version 1.1 (the "License"); you may not use this file except }
  23. { in compliance with the License. You may obtain a copy of the License at      }
  24. { http://www.mozilla.org/MPL/MPL-1.1.html                                      }
  25. {                                                                              }
  26. { Software distributed under the License is distributed on an "AS IS" basis,   }
  27. { WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }
  28. { the specific language governing rights and limitations under the License.    }
  29. {                                                                              }
  30. { Alternatively, the contents of this file may be used under the terms of the  }
  31. { GNU Lesser General Public License (the  "LGPL License"), in which case the   }
  32. { provisions of the LGPL License are applicable instead of those above.        }
  33. { If you wish to allow use of your version of this file only under the terms   }
  34. { of the LGPL License and not to allow others to use your version of this file }
  35. { under the MPL, indicate your decision by deleting  the provisions above and  }
  36. { replace  them with the notice and other provisions required by the LGPL      }
  37. { License.  If you do not delete the provisions above, a recipient may use     }
  38. { your version of this file under either the MPL or the LGPL License.          }
  39. {                 }
  40. { For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }
  41. {                 }
  42. {******************************************************************************}
  43. unit JwaLmApiBuf;
  44. {$WEAKPACKAGEUNIT}
  45. {$HPPEMIT ''}
  46. {$HPPEMIT '#include "lmapibuf.h"'}
  47. {$HPPEMIT ''}
  48. {$I WINDEFINES.INC}
  49. interface
  50. uses
  51.   JwaLmCons, JwaWinType;
  52. //
  53. // Function Prototypes
  54. //
  55. function NetApiBufferAllocate(ByteCount: DWORD; var Buffer: LPVOID): NET_API_STATUS; stdcall;
  56. {$EXTERNALSYM NetApiBufferAllocate}
  57. function NetApiBufferFree(Buffer: LPVOID): NET_API_STATUS; stdcall;
  58. {$EXTERNALSYM NetApiBufferFree}
  59. function NetApiBufferReallocate(OldBuffer: LPVOID; NewByteCount: DWORD; var NewBuffer: LPVOID): NET_API_STATUS; stdcall;
  60. {$EXTERNALSYM NetApiBufferReallocate}
  61. function NetApiBufferSize(Buffer: LPVOID; var ByteCount: DWORD): NET_API_STATUS; stdcall;
  62. {$EXTERNALSYM NetApiBufferSize}
  63. //
  64. // The following private function will go away eventually.
  65. // Call NetApiBufferAllocate instead.
  66. //
  67. function NetapipBufferAllocate(ByteCount: DWORD; var Buffer: LPVOID): NET_API_STATUS; stdcall;
  68. {$EXTERNALSYM NetapipBufferAllocate}
  69. implementation
  70. {$IFDEF DYNAMIC_LINK}
  71. var
  72.   _NetApiBufferAllocate: Pointer;
  73. function NetApiBufferAllocate;
  74. begin
  75.   GetProcedureAddress(_NetApiBufferAllocate, netapi32, 'NetApiBufferFree');
  76.   asm
  77.     mov esp, ebp
  78.     pop ebp
  79.     jmp [_NetApiBufferAllocate]
  80.   end;
  81. end;
  82. {$ELSE}
  83. function NetApiBufferAllocate; external netapi32 name 'NetApiBufferFree';
  84. {$ENDIF DYNAMIC_LINK}
  85. {$IFDEF DYNAMIC_LINK}
  86. var
  87.   _NetApiBufferFree: Pointer;
  88. function NetApiBufferFree;
  89. begin
  90.   GetProcedureAddress(_NetApiBufferFree, netapi32, 'NetApiBufferFree');
  91.   asm
  92.     mov esp, ebp
  93.     pop ebp
  94.     jmp [_NetApiBufferFree]
  95.   end;
  96. end;
  97. {$ELSE}
  98. function NetApiBufferFree; external netapi32 name 'NetApiBufferFree';
  99. {$ENDIF DYNAMIC_LINK}
  100. {$IFDEF DYNAMIC_LINK}
  101. var
  102.   _NetApiBufferReallocate: Pointer;
  103. function NetApiBufferReallocate;
  104. begin
  105.   GetProcedureAddress(_NetApiBufferReallocate, netapi32, 'NetApiBufferReallocate');
  106.   asm
  107.     mov esp, ebp
  108.     pop ebp
  109.     jmp [_NetApiBufferReallocate]
  110.   end;
  111. end;
  112. {$ELSE}
  113. function NetApiBufferReallocate; external netapi32 name 'NetApiBufferReallocate';
  114. {$ENDIF DYNAMIC_LINK}
  115. {$IFDEF DYNAMIC_LINK}
  116. var
  117.   _NetApiBufferSize: Pointer;
  118. function NetApiBufferSize;
  119. begin
  120.   GetProcedureAddress(_NetApiBufferSize, netapi32, 'NetApiBufferSize');
  121.   asm
  122.     mov esp, ebp
  123.     pop ebp
  124.     jmp [_NetApiBufferSize]
  125.   end;
  126. end;
  127. {$ELSE}
  128. function NetApiBufferSize; external netapi32 name 'NetApiBufferSize';
  129. {$ENDIF DYNAMIC_LINK}
  130. {$IFDEF DYNAMIC_LINK}
  131. var
  132.   _NetapipBufferAllocate: Pointer;
  133. function NetapipBufferAllocate;
  134. begin
  135.   GetProcedureAddress(_NetapipBufferAllocate, netapi32, 'NetapipBufferAllocate');
  136.   asm
  137.     mov esp, ebp
  138.     pop ebp
  139.     jmp [_NetapipBufferAllocate]
  140.   end;
  141. end;
  142. {$ELSE}
  143. function NetapipBufferAllocate; external netapi32 name 'NetapipBufferAllocate';
  144. {$ENDIF DYNAMIC_LINK}
  145. end.