Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

432 lines
15 KiB

  1. /****************************************************************************\
  2. OEMFLDR.C / OPK Wizard (OPKWIZ.EXE)
  3. Microsoft Confidential
  4. Copyright (c) Microsoft Corporation 2000
  5. All rights reserved
  6. Source file for the OPK Wizard that contains the external and internal
  7. functions used by the "Start Menu OEM branding" wizard page.
  8. 11/2000 - Sankar Ramasubramanian (SANKAR)
  9. 3/2000 - Sankar Ramasubramanian (SANKAR):
  10. Changed the code to get graphic images and a link.
  11. \****************************************************************************/
  12. //
  13. // Include File(s):
  14. //
  15. #include "pch.h"
  16. #include "wizard.h"
  17. #include "resource.h"
  18. //
  19. // Internal Function Prototype(s):
  20. //
  21. static BOOL OnInit(HWND, HWND, LPARAM);
  22. static void OnCommand(HWND, INT, HWND, UINT);
  23. static BOOL OnNext(HWND hwnd);
  24. static void EnableControls(HWND, UINT, BOOL);
  25. static int GetIndexOfPushButton(int id);
  26. #define LOC_FILENAME_OEMLINK_ICON _T("OemLinkIcon")
  27. #define LOC_FILENAME_OEMLINK_PATH _T("OemLink")
  28. #define LOC_FILENAME_OEMLINK_ICON_EXT _T(".ico")
  29. #define LOC_FILENAME_OEMLINK_HTML_EXT _T(".htm")
  30. #define ENV_WINDIR_SYS32 _T("%WINDIR%\\System32")
  31. typedef struct {
  32. LPTSTR pszIniKeyNameOriginal;
  33. LPTSTR pszIniKeyNameLocal;
  34. int idDlgItemStatic;
  35. int idDlgItemEdit;
  36. int idDlgItemButton;
  37. LPTSTR pszLocalFileName;
  38. LPTSTR pszExtension;
  39. } OEMDETAILS;
  40. static OEMDETAILS OemInfo[] = {
  41. {
  42. INI_KEY_OEMLINK_ICON_ORIGINAL,
  43. INI_KEY_OEMLINK_ICON_LOCAL,
  44. IDC_OEMLINK_STATIC_ICON,
  45. IDC_OEM_LINK_ICON,
  46. IDC_OEMLINK_ICON_BUTTON,
  47. LOC_FILENAME_OEMLINK_ICON,
  48. LOC_FILENAME_OEMLINK_ICON_EXT
  49. },
  50. {
  51. INI_KEY_OEMLINK_PATH_ORIGINAL,
  52. INI_KEY_OEMLINK_PATH_LOCAL,
  53. IDC_OEMLINK_LINK_STATIC,
  54. IDC_OEM_LINK_PATH,
  55. IDC_OEMLINK_LINK_BUTTON,
  56. LOC_FILENAME_OEMLINK_PATH,
  57. NULLSTR //We need to use the extension given by the user.
  58. //because it could be .exe or .htm
  59. }
  60. };
  61. //
  62. // External Function(s):
  63. //
  64. LRESULT CALLBACK OemLinkDlgProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
  65. {
  66. switch (uMsg)
  67. {
  68. HANDLE_MSG(hwnd, WM_INITDIALOG, OnInit);
  69. HANDLE_MSG(hwnd, WM_COMMAND, OnCommand);
  70. case WM_NOTIFY:
  71. switch ( ((NMHDR FAR *) lParam)->code )
  72. {
  73. case PSN_KILLACTIVE:
  74. case PSN_RESET:
  75. case PSN_WIZFINISH:
  76. case PSN_WIZBACK:
  77. break;
  78. case PSN_WIZNEXT:
  79. if ( !OnNext(hwnd) )
  80. WIZ_FAIL(hwnd);
  81. break;
  82. case PSN_SETACTIVE:
  83. g_App.dwCurrentHelp = IDH_OEMFOLDER;
  84. WIZ_BUTTONS(hwnd, PSWIZB_BACK | PSWIZB_FINISH);
  85. // Press next if the user is in auto mode
  86. //
  87. WIZ_NEXTONAUTO(hwnd, PSBTN_NEXT);
  88. break;
  89. case PSN_QUERYCANCEL:
  90. WIZ_CANCEL(hwnd);
  91. break;
  92. case PSN_HELP:
  93. WIZ_HELP();
  94. break;
  95. default:
  96. return FALSE;
  97. }
  98. break;
  99. default:
  100. return FALSE;
  101. }
  102. return TRUE;
  103. }
  104. // NOTE: pszLocal is assumed to be at least MAX_PATH length
  105. void AppendCorrectExtension(int iIndex, LPTSTR pszLocal, LPTSTR pszSource)
  106. {
  107. LPTSTR pszExt = NULL;
  108. HRESULT hrCat;
  109. // Find the appropriate extension.
  110. if(OemInfo[iIndex].pszExtension[0]) //If we know what extension we look for....
  111. pszExt = OemInfo[iIndex].pszExtension; //use it.
  112. else
  113. {
  114. // It could be HTM or EXE. So, use the one in the source.
  115. pszExt = PathFindExtension(pszSource);
  116. // If source doesn't have an extension, use the default HTM
  117. if( pszExt && (*pszExt == _T('\0')) )
  118. pszExt = LOC_FILENAME_OEMLINK_HTML_EXT;
  119. }
  120. //Append the extension to the local filename.
  121. hrCat=StringCchCat(pszLocal, MAX_PATH, pszExt);
  122. }
  123. //
  124. // Internal Function(s):
  125. //
  126. static BOOL OnInit(HWND hwnd, HWND hwndFocus, LPARAM lParam)
  127. {
  128. int iIndex;
  129. BOOL fValidData = TRUE; //Assume that the data is valid.
  130. TCHAR szLocal[MAX_PATH],
  131. szSource[MAX_PATH];
  132. szSource[0] = NULLCHR;
  133. //Read the Oem Link Static Text.
  134. GetPrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_LINKTEXT, NULLSTR, szSource, AS(szSource), g_App.szOpkWizIniFile);
  135. // Limit the size of the edit box.
  136. //
  137. SendDlgItemMessage(hwnd, IDC_OEM_LINK_TEXT, EM_LIMITTEXT, STRSIZE(szSource) - 1, 0);
  138. SetDlgItemText(hwnd, IDC_OEM_LINK_TEXT, szSource);
  139. //Read the Oem Link's infotip text.
  140. GetPrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_INFOTIP, NULLSTR, szSource, AS(szSource), g_App.szOpkWizIniFile);
  141. // Limit the size of infotip editbox to 128 characters.
  142. //
  143. SendDlgItemMessage(hwnd, IDC_OEM_LINK_INFOTIP, EM_LIMITTEXT, 128, 0);
  144. SetDlgItemText(hwnd, IDC_OEM_LINK_INFOTIP, szSource);
  145. for(iIndex = 0; iIndex < ARRAYSIZE(OemInfo); iIndex++)
  146. {
  147. // Should always look for the source file name.
  148. //
  149. szSource[0] = NULLCHR;
  150. GetPrivateProfileString(INI_SEC_OEMLINK, OemInfo[iIndex].pszIniKeyNameOriginal, NULLSTR, szSource, AS(szSource), g_App.szOpkWizIniFile);
  151. // Now figure out the local file name.
  152. //
  153. lstrcpyn(szLocal, g_App.szTempDir,AS(szLocal));
  154. AddPathN(szLocal, DIR_OEM_SYSTEM32,AS(szLocal));
  155. if ( GET_FLAG(OPK_BATCHMODE) )
  156. CreatePath(szLocal);
  157. AddPathN(szLocal, OemInfo[iIndex].pszLocalFileName,AS(szLocal));
  158. // Append the appropriate extension.
  159. AppendCorrectExtension(iIndex, szLocal, szSource);
  160. // Limit the size of the edit box.
  161. //
  162. SendDlgItemMessage(hwnd, OemInfo[iIndex].idDlgItemEdit, EM_LIMITTEXT, STRSIZE(szSource) - 1, 0);
  163. // Check for batch mode and copy the file if we need to.
  164. //
  165. if ( GET_FLAG(OPK_BATCHMODE) && szSource[0] && FileExists(szSource) )
  166. CopyResetFileErr(GetParent(hwnd), szSource, szLocal);
  167. // Check for the file to decide if we enable the
  168. // option or not.
  169. //
  170. if ( szSource[0] && FileExists(szLocal) )
  171. {
  172. SetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, szSource);
  173. }
  174. else
  175. {
  176. fValidData = FALSE;
  177. }
  178. }
  179. //
  180. // If all the data is valid, we enable the controls.
  181. if(fValidData)
  182. {
  183. CheckDlgButton(hwnd, IDC_OEMLINK_CHECK, TRUE);
  184. EnableControls(hwnd, IDC_OEMLINK_CHECK, TRUE);
  185. }
  186. else
  187. {
  188. CheckDlgButton(hwnd, IDC_OEMLINK_CHECK, FALSE);
  189. EnableControls(hwnd, IDC_OEMLINK_CHECK, FALSE);
  190. }
  191. return FALSE;
  192. }
  193. static void OnCommand(HWND hwnd, INT id, HWND hwndCtl, UINT codeNotify)
  194. {
  195. TCHAR szFileName[MAX_PATH];
  196. int iIndex;
  197. int iFilter, iDefExtension;
  198. switch ( id )
  199. {
  200. case IDC_OEMLINK_CHECK:
  201. EnableControls(hwnd, id, IsDlgButtonChecked(hwnd, id) == BST_CHECKED);
  202. break;
  203. case IDC_OEMLINK_ICON_BUTTON:
  204. case IDC_OEMLINK_LINK_BUTTON:
  205. //Get the correct filter and Default extension
  206. if(id == IDC_OEMLINK_LINK_BUTTON)
  207. {
  208. //We accept only .HTM and .HTML files here.
  209. iFilter = IDS_HTMLFILTER;
  210. iDefExtension = 0;
  211. }
  212. else
  213. {
  214. //We accept only .ICO files here.
  215. iFilter = IDS_ICO_FILTER;
  216. iDefExtension = IDS_ICO;
  217. }
  218. szFileName[0] = NULLCHR;
  219. iIndex = GetIndexOfPushButton(id);
  220. if(iIndex >= 0)
  221. {
  222. GetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, szFileName, STRSIZE(szFileName));
  223. if ( BrowseForFile(GetParent(hwnd), IDS_BROWSE, iFilter, iDefExtension, szFileName, STRSIZE(szFileName), g_App.szBrowseFolder, 0) )
  224. {
  225. LPTSTR lpFilePart = NULL;
  226. TCHAR szTargetFile[MAX_PATH];
  227. // Save the last browse directory.
  228. //
  229. if ( GetFullPathName(szFileName, AS(g_App.szBrowseFolder), g_App.szBrowseFolder, &lpFilePart) && g_App.szBrowseFolder[0] && lpFilePart )
  230. *lpFilePart = NULLCHR;
  231. lstrcpyn(szTargetFile, g_App.szTempDir,AS(szTargetFile));
  232. AddPathN(szTargetFile, DIR_OEM_SYSTEM32,AS(szTargetFile));
  233. CreatePath(szTargetFile);
  234. AddPathN(szTargetFile, OemInfo[iIndex].pszLocalFileName,AS(szTargetFile));
  235. AppendCorrectExtension(iIndex, szTargetFile, szFileName);
  236. if ( CopyResetFileErr(GetParent(hwnd), szFileName, szTargetFile) )
  237. SetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, szFileName);
  238. }
  239. }
  240. break;
  241. }
  242. }
  243. static BOOL OnNext(HWND hwnd)
  244. {
  245. int iIndex;
  246. TCHAR szTargetFile[MAX_PATH],
  247. szSourceFile[MAX_PATH];
  248. LPTSTR psz;
  249. BOOL fOemLinkEnabled = FALSE;
  250. fOemLinkEnabled = (IsDlgButtonChecked(hwnd, IDC_OEMLINK_CHECK) == BST_CHECKED);
  251. //Save the OEM text for the link!
  252. szSourceFile[0] = NULLCHR;
  253. GetDlgItemText(hwnd, IDC_OEM_LINK_TEXT, szSourceFile, STRSIZE(szSourceFile));
  254. // Save the text in the batch file.
  255. WritePrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_LINKTEXT, szSourceFile, g_App.szOpkWizIniFile);
  256. // Save the text in WinBom.Ini also. This is used by factory.exe
  257. if (!fOemLinkEnabled)
  258. psz = NULL;
  259. else
  260. psz = szSourceFile;
  261. WritePrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_LINKTEXT, psz, g_App.szWinBomIniFile);
  262. //Save the OEM Infotip text for the link!
  263. szSourceFile[0] = NULLCHR;
  264. GetDlgItemText(hwnd, IDC_OEM_LINK_INFOTIP, szSourceFile, STRSIZE(szSourceFile));
  265. // Save the text in the batch file.
  266. WritePrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_INFOTIP, szSourceFile, g_App.szOpkWizIniFile);
  267. // Save the text in WinBom.Ini also. This is used by factory.exe
  268. if (!fOemLinkEnabled)
  269. psz = NULL;
  270. else
  271. psz = szSourceFile;
  272. WritePrivateProfileString(INI_SEC_OEMLINK, INI_KEY_OEMLINK_INFOTIP, psz, g_App.szWinBomIniFile);
  273. for(iIndex = 0; iIndex < ARRAYSIZE(OemInfo); iIndex++)
  274. {
  275. // Prepare OEM link bitmap as target file.
  276. //
  277. lstrcpyn(szTargetFile, g_App.szTempDir,AS(szTargetFile));
  278. AddPathN(szTargetFile, DIR_OEM_SYSTEM32,AS(szTargetFile));
  279. AddPathN(szTargetFile, OemInfo[iIndex].pszLocalFileName,AS(szTargetFile));
  280. if (fOemLinkEnabled)
  281. {
  282. // Validation consists of verifying the files they have entered were actually copied.
  283. //
  284. szSourceFile[0] = NULLCHR;
  285. GetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, szSourceFile, STRSIZE(szSourceFile));
  286. AppendCorrectExtension(iIndex, szTargetFile, szSourceFile);
  287. if ( !szSourceFile[0] || !FileExists(szTargetFile) )
  288. {
  289. MsgBox(GetParent(hwnd), szSourceFile[0] ? IDS_NOFILE : IDS_BLANKFILE, IDS_APPNAME, MB_ERRORBOX, szSourceFile);
  290. SetFocus(GetDlgItem(hwnd, OemInfo[iIndex].idDlgItemButton));
  291. return FALSE;
  292. }
  293. // Save the Original name in the batch file.
  294. //
  295. WritePrivateProfileString(INI_SEC_OEMLINK, OemInfo[iIndex].pszIniKeyNameOriginal, szSourceFile, g_App.szOpkWizIniFile);
  296. // Create the target filename in a generic way.
  297. // For example, "%WINDIR%\System32\<LocalFileName>"
  298. lstrcpyn(szTargetFile, ENV_WINDIR_SYS32,AS(szTargetFile)); // %WINDIR%\System32
  299. AddPathN(szTargetFile, OemInfo[iIndex].pszLocalFileName,AS(szTargetFile));
  300. AppendCorrectExtension(iIndex, szTargetFile, szSourceFile);
  301. // Save the local filename in WinBom.Ini. This is used by factory.exe
  302. WritePrivateProfileString(INI_SEC_OEMLINK, OemInfo[iIndex].pszIniKeyNameLocal, szTargetFile, g_App.szWinBomIniFile);
  303. }
  304. else
  305. {
  306. szSourceFile[0] = NULLCHR;
  307. GetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, szSourceFile, STRSIZE(szSourceFile));
  308. AppendCorrectExtension(iIndex, szTargetFile, szSourceFile);
  309. //Delete the local files.
  310. DeleteFile(szTargetFile);
  311. // Remove the Source path!
  312. //
  313. WritePrivateProfileString(INI_SEC_OEMLINK, OemInfo[iIndex].pszIniKeyNameOriginal, NULL, g_App.szOpkWizIniFile);
  314. //
  315. // Make the edit controls blank!
  316. //
  317. SetDlgItemText(hwnd, OemInfo[iIndex].idDlgItemEdit, NULLSTR);
  318. //
  319. // Remove the local filenames from Ini files.
  320. WritePrivateProfileString(INI_SEC_OEMLINK, OemInfo[iIndex].pszIniKeyNameLocal, NULL, g_App.szWinBomIniFile);
  321. }
  322. }
  323. return TRUE;
  324. }
  325. static void EnableControls(HWND hwnd, UINT uId, BOOL fEnable)
  326. {
  327. switch ( uId )
  328. {
  329. case IDC_OEMLINK_CHECK:
  330. {
  331. int iIndex;
  332. for(iIndex = 0; iIndex < ARRAYSIZE(OemInfo); iIndex++)
  333. {
  334. //Enable/Disable the Static control.
  335. EnableWindow(GetDlgItem(hwnd, OemInfo[iIndex].idDlgItemStatic), fEnable);
  336. //Enable/Disable the Edit control.
  337. EnableWindow(GetDlgItem(hwnd, OemInfo[iIndex].idDlgItemEdit), fEnable);
  338. //Enable/Disable the Push Button control.
  339. EnableWindow(GetDlgItem(hwnd, OemInfo[iIndex].idDlgItemButton), fEnable);
  340. }
  341. //Enable disable the Oem Link Text static control
  342. EnableWindow(GetDlgItem(hwnd, IDC_OEMLINK_STATIC_TEXT), fEnable);
  343. //Enable/Disable the Edit control.
  344. EnableWindow(GetDlgItem(hwnd, IDC_OEM_LINK_TEXT), fEnable);
  345. //Enable disable the Oem Link Infotip Text static control
  346. EnableWindow(GetDlgItem(hwnd, IDC_OEMLINK_STATIC_INFOTIP), fEnable);
  347. //Enable/Disable the oem link Infotip Edit control.
  348. EnableWindow(GetDlgItem(hwnd, IDC_OEM_LINK_INFOTIP), fEnable);
  349. }
  350. break;
  351. }
  352. }
  353. //Given the id of a Pushbutton in our dlg, get the index of the item in our OemInfo struct
  354. static int GetIndexOfPushButton(int id)
  355. {
  356. int iIndex;
  357. for(iIndex = 0; iIndex < ARRAYSIZE(OemInfo); iIndex++)
  358. {
  359. if(id == OemInfo[iIndex].idDlgItemButton)
  360. return iIndex;
  361. }
  362. return -1; //Error!
  363. }