jwaprofinfo.pas 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. {******************************************************************************}
  2. { }
  3. { Profile Info Structures 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: profinfo.h, released June 2000. The original Pascal }
  9. { code is: ProfInfo.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 JwaProfInfo;
  43. {$WEAKPACKAGEUNIT}
  44. {$HPPEMIT ''}
  45. {$HPPEMIT '#include "profinfo.h"'}
  46. {$HPPEMIT ''}
  47. {$I jediapilib.inc}
  48. interface
  49. uses
  50. JwaWinType;
  51. type
  52. LPPROFILEINFOA = ^PROFILEINFOA;
  53. {$EXTERNALSYM LPPROFILEINFOA}
  54. _PROFILEINFOA = record
  55. dwSize: DWORD; // Set to sizeof(PROFILEINFO) before calling
  56. dwFlags: DWORD; // See flags above
  57. lpUserName: LPSTR; // User name (required)
  58. lpProfilePath: LPSTR; // Roaming profile path (optional, can be NULL)
  59. lpDefaultPath: LPSTR; // Default user profile path (optional, can be NULL)
  60. lpServerName: LPSTR; // Validating domain controller name in netbios format (optional, can be NULL but group NT4 style policy won't be applied)
  61. lpPolicyPath: LPSTR; // Path to the NT4 style policy file (optional, can be NULL)
  62. hProfile: HANDLE; // Filled in by the function. Registry key handle open to the root.
  63. end;
  64. {$EXTERNALSYM _PROFILEINFOA}
  65. PROFILEINFOA = _PROFILEINFOA;
  66. {$EXTERNALSYM PROFILEINFOA}
  67. TProfileInfoA = PROFILEINFOA;
  68. PProfileInfoA = LPPROFILEINFOA;
  69. LPPROFILEINFOW = ^PROFILEINFOW;
  70. {$EXTERNALSYM LPPROFILEINFOW}
  71. _PROFILEINFOW = record
  72. dwSize: DWORD; // Set to sizeof(PROFILEINFO) before calling
  73. dwFlags: DWORD; // See flags above
  74. lpUserName: LPWSTR; // User name (required)
  75. lpProfilePath: LPWSTR; // Roaming profile path (optional, can be NULL)
  76. lpDefaultPath: LPWSTR; // Default user profile path (optional, can be NULL)
  77. lpServerName: LPWSTR; // Validating domain controller name in netbios format (optional, can be NULL but group NT4 style policy won't be applied)
  78. lpPolicyPath: LPWSTR; // Path to the NT4 style policy file (optional, can be NULL)
  79. hProfile: HANDLE; // Filled in by the function. Registry key handle open to the root.
  80. end;
  81. {$EXTERNALSYM _PROFILEINFOW}
  82. PROFILEINFOW = _PROFILEINFOW;
  83. {$EXTERNALSYM PROFILEINFOW}
  84. TProfileInfoW = PROFILEINFOW;
  85. PProfileInfoW = LPPROFILEINFOW;
  86. {$IFDEF UNICODE}
  87. PROFILEINFO = PROFILEINFOW;
  88. {$EXTERNALSYM PROFILEINFO}
  89. LPPROFILEINFO = LPPROFILEINFOW;
  90. {$EXTERNALSYM LPPROFILEINFO}
  91. TProfileInfo = TProfileInfoW;
  92. PProfileInfo = PProfileInfoW;
  93. {$ELSE}
  94. PROFILEINFO = PROFILEINFOA;
  95. {$EXTERNALSYM PROFILEINFO}
  96. LPPROFILEINFO = LPPROFILEINFOA;
  97. {$EXTERNALSYM LPPROFILEINFO}
  98. TProfileInfo = TProfileInfoA;
  99. PProfileInfo = PProfileInfoA;
  100. {$ENDIF UNICODE}
  101. implementation
  102. end.